Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Solarprognose

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Solarprognose

    This topic has been deleted. Only users with topic management privileges can see it.
    • wendy2702
      wendy2702 @Palm_Maniac last edited by

      @palm_maniac sagte in Solarprognose:

      @wendy2702

      Ich habe 3 Browser darauf los gelassen inkl. Neustart des PCs, Restarts der Instanzen usw.

      Wenn ich das andere Skript hier aus dem Beitrag starte, dann werden die entsprechenden Datenpunkte sauber angelegt, nur in diesem nicht.

      Welches andere?

      Palm_Maniac 1 Reply Last reply Reply Quote 0
      • Palm_Maniac
        Palm_Maniac @wendy2702 last edited by

        @wendy2702

        Das hier:

        
        const url = 'http://www.solarprognose.de/web/solarprediction/api/v1?_format=json&access-token=....&item=inverter&id=412&type=hourly';
        const path = '0_userdata.0.SolarGraph.';
        const idLeistung_Energie = path + 'Leistung_Energie';
        const idEnergieMaxHeute = path + 'EnergieMaxHeute';
        const idEnergieMaxMorgen = path + 'EnergieMaxMorgen';
         
        var Leistung_Energie = {
            "axisLabels": ["8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18", "8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18"],
            "graphs": [{
                "data": [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
                "type": "line",
                "legendText":"Leistung",
                "yAxis_min": 0,
                "yAxis_max": 8,
                "yAxis_step": 1,
                "yAxis_position": "left",
                "yAxis_appendix": " kW",
                "datalabel_show": false
            },
            {
                "data": [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
                "type": "line",
                "line_UseFillColor": true,
                "legendText":"Energie",
                "yAxis_min": 0,
                "yAxis_max": 64,
                "yAxis_step": 8,
                "yAxis_position": "right",
                "yAxis_appendix": " kWh",
                "yAxis_color": "#91d430",
                "datalabel_show": false
            }
            ]
        };
         
        createState(idLeistung_Energie, JSON.stringify(Leistung_Energie), {type: 'string', name: 'Leistung_Energie', role: 'table'}); 
        createState(idEnergieMaxHeute, 0, {type: 'number', role: 'value', name: 'EnergieMaxHeute', read: true, write: false, unit: 'kWh'});
        createState(idEnergieMaxMorgen, 0, {type: 'number', role: 'value', name: 'EnergieMaxMorgen', read: true, write: false, unit: 'kWh'});
         
        schedule('5 7,9,12,14,16,18 * * *', function() { 
            request(url, function (error, response, result) {
                if(error) log(error, 'error');
                else {
                    let obj = JSON.parse(result);
                    if(obj.status) log('Fehler: ' + obj.status, 'warn');
                    else {
                        let data = obj.data;
                        Leistung_Energie.axisLabels = [];
                        Leistung_Energie.graphs[0].data = [];
                        Leistung_Energie.graphs[1].data = [];
                        let i = 0;
                        for(let entry in data) {
                            let time = formatDate(parseInt(entry), 'hh');
                            Leistung_Energie.axisLabels.push(time);
                            Leistung_Energie.graphs[0].data.push(data[entry][0]);
                            Leistung_Energie.graphs[1].data.push(data[entry][1]);
                            if (time == '19')
                               if (i == 0) { setState(idEnergieMaxHeute, data[entry][1], true);  i = i+1 }
                               else         setState(idEnergieMaxMorgen, data[entry][1], true);
                        }
                        setState(idLeistung_Energie, JSON.stringify(Leistung_Energie), true);               
                    }
                }
            });
        });
         
        
        
        S D 2 Replies Last reply Reply Quote 0
        • S
          Streit187 @Palm_Maniac last edited by

          @palm_maniac Also ich habe gerade dein Skript genommen und bei mir gestartet. Den schedule abgewartet und alle Datenpunkte wurden wie erwartet angelegt. Damit ist ein Fehler im Skript ausgeschlossen.

          Palm_Maniac 1 Reply Last reply Reply Quote 0
          • Palm_Maniac
            Palm_Maniac @Streit187 last edited by

            @streit187

            Das ist doch verrückt. Was läuft denn dann bei mir schief? Ich habe so viele Java- und Blockly Skripte laufen und keins macht Probleme, es ging immer...

            1 Reply Last reply Reply Quote 0
            • Palm_Maniac
              Palm_Maniac last edited by Palm_Maniac

              Ich habe jetzt mal das Skript zwischengespeichert, gelöscht und neu angelegt und was soll ich sagen, jetzt läuft es. Alle Datenpunkte wurden angelegt und gefüllt. Perfekt. Jetzt gehts ans Auswerten und gleich zur nächsten Frage.

              Momentan legt das Skript ja jeden Tag extra und immer wieder neu an. Ich habe zur Zeit den kostenlosen Zugang mit den Prognosen für heute und morgen. Damit man z.b. Grafana drauf los lassen kann, wäre es besser wenn es konstante Datenpunkte gäbe, die immer aktualisiert werden, also z.b. wie heute anstatt der Anlage 03-10 und 03-11 einfach nur "Heute" und Morgen". Dann kann man versuchen es irgendwie in Grafana einzubringen und müßte nicht jeden Tag Hand anlegen. Interessant sind ja nur der aktuelle Tag und die Zukunft, nicht das was Gestern war.

              Wo und wie müßte man denn dann im Skript Hand anlegen?

              Nutz hier jemand Grafana und hat die Prognosedaten dort eingebunden? Wenn ja wie, denn über die InfluxDB wirds schwierig.

              S 1 Reply Last reply Reply Quote 0
              • S
                Streit187 @Palm_Maniac last edited by

                @palm_maniac Das von dir verwendete Skript legt doch bereits Datenpunkte mit heute und morgen gefolgt von der Uhrzeit an. Hast du dann nicht was du brauchst? Sieht das bei dir nicht wie auf dem folgenden Bild aus?
                Grafana nutze ich nicht. Unbenannt.JPG

                1 Reply Last reply Reply Quote 0
                • Palm_Maniac
                  Palm_Maniac last edited by Palm_Maniac

                  @streit187

                  Ja, aber da das Datum als Datenpunktname genutzt wird, ist in dem von mir geposteten Skript so, hatte ich erwartet, das morgen eine neue Gruppe unter 03_12 angelegt wird. Das wäre extrem Mühsam da eine Auswertung, egal mit welchem Programm, durchzuführen. Da steckt mein Problem.

                  S 1 Reply Last reply Reply Quote 0
                  • S
                    Streit187 @Palm_Maniac last edited by

                    @palm_maniac Auch wenn sich mir der Sinn nicht erschließt weshalb ich heute die Prognosedaten von gestern behalten sollte würde deine Erwartung dich ja mit Datenpunkten "zumüllen".
                    Wenn du aber die Daten von gestern usw. haben möchtest musst du die Datenpunkte aufzeichnen sprich den History Adapter, Datenbank etc. einschalten.

                    Palm_Maniac 1 Reply Last reply Reply Quote 0
                    • Palm_Maniac
                      Palm_Maniac @Streit187 last edited by

                      @streit187

                      Nein, das ist ja meine Rede, ich brauche die alten Daten nicht, aber das Skript wird sie erzeugen, deshalb meine Frage wo man das Skript abändern kann/muß, damit nur diese 2 Datenpunkte angelegt und zukünftig aktualisiert werden.

                      S 1 Reply Last reply Reply Quote 0
                      • S
                        Streit187 @Palm_Maniac last edited by

                        @palm_maniac Nein, das tut das Skript nicht. Morgen ist Morgen heute und übermorgen morgen. Es bleibt bei diesen beiden Ordnern mit den dazugehörigen Datenpunkten und die Werte werden genau so aktualisiert wie du es brauchst.

                        Palm_Maniac 1 Reply Last reply Reply Quote 0
                        • Palm_Maniac
                          Palm_Maniac @Streit187 last edited by

                          @streit187

                          Schau mal:

                          let time = formatDate(parseInt(entry), 'MM-DD.hh:mm');
                                              if(existsState(idLeistung + time)) setState(idLeistung + time, data[entry][0], true);
                                              else createState(idLeistung + time, data[entry][0], {
                                                  type: 'number', 
                                                  role: 'value', 
                                                  name: 'Solarleistung ' + formatDate(parseInt(entry), 'DD.MM. hh:mm'),
                                                  read: true,
                                                  write: false,
                                                  unit: 'kW'
                          

                          Hier wird doch das Datum geparst und weiter unten in den Namen/Pfad eingebaut, was doch dazu führt, dass immer neue Ordner entstehen nach dem Schema 03-10, 03-11, 03-12 usw. Die Begriffe "Heute" und "Morgen" tauchen in diesem Skript nicht auf, so würde es mir aber reichen.

                          Oder verstehe ich das Skript da falsch?

                          S 1 Reply Last reply Reply Quote 0
                          • S
                            Streit187 @Palm_Maniac last edited by

                            @palm_maniac Wo kommt denn dieser Code her? Der ist nicht Bestandteil von deinem Ursprünglichen Skript in https://forum.iobroker.net/topic/37314/solarprognose/73.

                            Palm_Maniac 1 Reply Last reply Reply Quote 0
                            • Palm_Maniac
                              Palm_Maniac @Streit187 last edited by

                              @streit187

                              Doch, hab gerade nochmal nachgeschaut.

                              1 Reply Last reply Reply Quote 0
                              • Palm_Maniac
                                Palm_Maniac last edited by

                                Skript läuft jetzt mit HEUTE und MORGEN. Jetzt muß ich nur noch irgendwie die Daten in meine Grafana-Darstellung bekommen, dann ist es Perfekt. 🙂

                                1 Reply Last reply Reply Quote 0
                                • Gargano
                                  Gargano last edited by

                                  @palm_maniac sagte in Solarprognose:

                                  Jetzt muß ich nur noch irgendwie die Daten in meine Grafana-Darstellung bekommen, dann ist es Perfekt.

                                  Würde mich auch interessieren, wie das geht, die Daten von Morgen in Grafana

                                  Palm_Maniac 1 Reply Last reply Reply Quote 0
                                  • Palm_Maniac
                                    Palm_Maniac @Gargano last edited by

                                    @gargano

                                    Ja, das Hauptproblem ist der Zeitstempel, damit fällt eigentlich InfluxDB raus. Eventuell wäre es besser die Daten als JSON zubekommen, denn dafür gäbe es etwas für Grafana.

                                    Gargano 1 Reply Last reply Reply Quote 0
                                    • Gargano
                                      Gargano @Palm_Maniac last edited by

                                      @palm_maniac Ich hab das JSON-Chart vom Scrounger verwendet. Das geht auch in die Zukunft, weil man die X-Achse mit angeben kann.

                                      Palm_Maniac 1 Reply Last reply Reply Quote 0
                                      • Palm_Maniac
                                        Palm_Maniac @Gargano last edited by

                                        @gargano Damit haben wir die Daten aber noch nicht in Grafana. Ich habe es schon direkt versucht, das JSON-Plugin in Grafana stört sich aber an den Infos, die vor den Daten gesendet werden. Zumindest habe ich es nicht hinbekommen, ich bekam nur Fehlermeldungen beim Test.

                                        Gargano 1 Reply Last reply Reply Quote 0
                                        • Gargano
                                          Gargano @Palm_Maniac last edited by Gargano

                                          @palm_maniac Wie hast Du das denn gemacht mit der JSON API ? Welche Einstellung in den Datasources ?

                                          Palm_Maniac 1 Reply Last reply Reply Quote 0
                                          • Palm_Maniac
                                            Palm_Maniac @Gargano last edited by

                                            @gargano Mit der hab ich es auch nicht hinbekommen, mir fehlen da genauso wie dir die richtigen Einstellungen. Da meckert er schon beim Verbindungstest bei mir.

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            678
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

                                            adapter javascript solarprognose
                                            27
                                            157
                                            18447
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo