Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. Solarprognose

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.8k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.2k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.2k

Solarprognose

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
solarprognoseadapterjavascript
157 Beiträge 27 Kommentatoren 27.7k Aufrufe 30 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • Palm_ManiacP Palm_Maniac

    @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);               
                }
            }
        });
    });
     
    
    
    D Offline
    D Offline
    Diamand2k22
    schrieb am zuletzt editiert von
    #129

    @paul53
    Von hier und dann erweitert anstatt 18->22 uhr.

    Dieses Skript habe ich noch zusätzlich in das erste mit eingefügt am Ende, wo er dann Leistung und Energie jeweils seperat aufdröselt.

    const url = 'hier die komplette URL eintragen';
    const path = '0_userdata.0.Solar.';
    const idLeistung = path + 'Leistung.';
    const idEnergie  = path + 'Energie.';
     
    schedule('16 4-22 * * *', 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;
                    for(let entry in data) {
                        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'
                        });
                        if(existsState(idEnergie + time)) setState(idEnergie + time, data[entry][1], true);
                        else createState(idEnergie + time, data[entry][1], {
                            type: 'number', 
                            role: 'value', 
                            name: 'Solarenergie ' + formatDate(parseInt(entry), 'DD.MM. hh:mm'),
                            read: true,
                            write: false,
                            unit: 'kWh'
                        });
                    }
                }
            }
        });
    });
    
    

    @palm_maniac said in Solarprognose:

    @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);               
                }
            }
        });
    });
     
    
    
    paul53P 1 Antwort Letzte Antwort
    0
    • D Diamand2k22

      @paul53
      Von hier und dann erweitert anstatt 18->22 uhr.

      Dieses Skript habe ich noch zusätzlich in das erste mit eingefügt am Ende, wo er dann Leistung und Energie jeweils seperat aufdröselt.

      const url = 'hier die komplette URL eintragen';
      const path = '0_userdata.0.Solar.';
      const idLeistung = path + 'Leistung.';
      const idEnergie  = path + 'Energie.';
       
      schedule('16 4-22 * * *', 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;
                      for(let entry in data) {
                          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'
                          });
                          if(existsState(idEnergie + time)) setState(idEnergie + time, data[entry][1], true);
                          else createState(idEnergie + time, data[entry][1], {
                              type: 'number', 
                              role: 'value', 
                              name: 'Solarenergie ' + formatDate(parseInt(entry), 'DD.MM. hh:mm'),
                              read: true,
                              write: false,
                              unit: 'kWh'
                          });
                      }
                  }
              }
          });
      });
      
      

      @palm_maniac said in Solarprognose:

      @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);               
                  }
              }
          });
      });
       
      
      
      paul53P Offline
      paul53P Offline
      paul53
      schrieb am zuletzt editiert von paul53
      #130

      @diamand2k22
      Ändere mal Zeilen 61 bis 63 in

                          if (time == '22') {
                             if (i == 0) setState(idEnergieMaxHeute, data[entry][1], true);
                             else if(i == 1) setState(idEnergieMaxMorgen, data[entry][1], true);
                             i++;
                          }
                          if (i > 1) break;
      

      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

      D 1 Antwort Letzte Antwort
      0
      • paul53P paul53

        @diamand2k22
        Ändere mal Zeilen 61 bis 63 in

                            if (time == '22') {
                               if (i == 0) setState(idEnergieMaxHeute, data[entry][1], true);
                               else if(i == 1) setState(idEnergieMaxMorgen, data[entry][1], true);
                               i++;
                            }
                            if (i > 1) break;
        
        D Offline
        D Offline
        Diamand2k22
        schrieb am zuletzt editiert von
        #131

        @paul53

        das hat funktioniert, danke!

        S 1 Antwort Letzte Antwort
        0
        • D Diamand2k22

          @paul53

          das hat funktioniert, danke!

          S Offline
          S Offline
          SkeeveKlah
          schrieb am zuletzt editiert von
          #132

          Hi,
          als frisch gebackener Photonenjäger würde es mich interessieren wie die Daten der Prognose nach Grafana zu bekommen sind. Das es der eine oder andere versucht hat konnte ich im Threadverlauf lesen, aber wie gelingt es letztendlich?! Die Daten müssten nach meinem Verständnis zu erst in die InfluxDB?!
          Könnt Ihr einem PV- und Grafana-Neuling auf die Sprünge helfen?
          Danke!

          Grüße aus dem Sauerland

          Marc

          RPI4 8GB mit SSD-RAID1, ioBroker mit Debmatic

          D 1 Antwort Letzte Antwort
          0
          • D Offline
            D Offline
            drdoener
            schrieb am zuletzt editiert von
            #133

            Hallo zsm,
            habe die selbe Baustelle wie SkeeveKlah.
            Die Daten von Solarprognose kann ich einwandfrei über dieses Script hier und auch über eine selbst entwickelte Abfrage in Nodered beziehen.
            Ich möchte die Werte aber u.a. zur Visualiserung in Grafana in meiner influxdb haben.
            Aktuell mache ich den Workaround über einen weiteren Pi, auf dem "solaranzeige" läuft. Dort werden die Daten so mittels php-script in eine influx geschrieben:

            9b7a26c3-b91c-4437-8129-d3ff4c2d9711-grafik.png

            Dies würde ich gerne direkt (ohne den Umweg über "solaranzeige") umsetzen.

            Hat dies schon jmd umgesetzt oder einen guten Weg dafür auf Lager?

            Danke,
            Michael

            1 Antwort Letzte Antwort
            0
            • S SkeeveKlah

              Hi,
              als frisch gebackener Photonenjäger würde es mich interessieren wie die Daten der Prognose nach Grafana zu bekommen sind. Das es der eine oder andere versucht hat konnte ich im Threadverlauf lesen, aber wie gelingt es letztendlich?! Die Daten müssten nach meinem Verständnis zu erst in die InfluxDB?!
              Könnt Ihr einem PV- und Grafana-Neuling auf die Sprünge helfen?
              Danke!

              D Offline
              D Offline
              drdoener
              schrieb am zuletzt editiert von
              #134

              @skeeveklah
              Hi, hier findest Du eine Lösung, via Node-Red.

              https://forum.iobroker.net/topic/68650/object-daten-in-influx-db-speichern/21

              1 Antwort Letzte Antwort
              0
              • DocdanD Online
                DocdanD Online
                Docdan
                schrieb am zuletzt editiert von Docdan
                #135

                Bin noch recht neu hier im Forum, lese aber schon eine Weile mit und habe auch schon vieles erfolgreich mit eurer Hilfe eingerichtet.

                Hat jemand dieses Script noch im Einsatz oder nutzt ihr inzwischen einen anderen Weg, die Daten von "Solarprognose.de" in den IOB zu bekommen. Ich habe viele verschieden Versionen des Skriptes aus diesem Thread in JS ausprobiert, bekomme aber immer denselben Fehler:

                script.js.Smarthome.Solarprognose.Prognose: Fehler: -8
                

                Hier der code den ich benutze:

                const url = 'http://www.solarprognose.de/web/solarprediction/api/v1?_format=json&access-token=78f1........ce0f&item=inverter&id=43..&type=hourly';
                const path = '0_userdata.0.Solar.';
                const idLeistung = path + 'Leistung.';
                const idEnergie  = path + 'Energie.';
                 
                schedule('16 4-22 * * *', 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;
                                for(let entry in data) {
                                    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'
                                    });
                                    if(existsState(idEnergie + time)) setState(idEnergie + time, data[entry][1], true);
                                    else createState(idEnergie + time, data[entry][1], {
                                        type: 'number', 
                                        role: 'value', 
                                        name: 'Solarenergie ' + formatDate(parseInt(entry), 'DD.MM. hh:mm'),
                                        read: true,
                                        write: false,
                                        unit: 'kWh'
                                    });
                                }
                            }
                        }
                    });
                });
                 
                

                Hat jemand hierzu eine Idee oder kann nochmal ein funktionierendes Script posten?

                Danke,
                Jens

                GlasfaserG 1 Antwort Letzte Antwort
                0
                • DocdanD Online
                  DocdanD Online
                  Docdan
                  schrieb am zuletzt editiert von
                  #136

                  Soweit ich jetzt herausbekommen habe hat es mit dem Code in Zeile 7 zu tun:

                  request(url, function (error, response, result) {
                  

                  Der geht wohl so nicht mehr. Ich habe keine Ahnung von JS, kann da jemand helfen wie das Script umgeschrieben werden muss, damit es wieder funktioniert?

                  1 Antwort Letzte Antwort
                  0
                  • DocdanD Docdan

                    Bin noch recht neu hier im Forum, lese aber schon eine Weile mit und habe auch schon vieles erfolgreich mit eurer Hilfe eingerichtet.

                    Hat jemand dieses Script noch im Einsatz oder nutzt ihr inzwischen einen anderen Weg, die Daten von "Solarprognose.de" in den IOB zu bekommen. Ich habe viele verschieden Versionen des Skriptes aus diesem Thread in JS ausprobiert, bekomme aber immer denselben Fehler:

                    script.js.Smarthome.Solarprognose.Prognose: Fehler: -8
                    

                    Hier der code den ich benutze:

                    const url = 'http://www.solarprognose.de/web/solarprediction/api/v1?_format=json&access-token=78f1........ce0f&item=inverter&id=43..&type=hourly';
                    const path = '0_userdata.0.Solar.';
                    const idLeistung = path + 'Leistung.';
                    const idEnergie  = path + 'Energie.';
                     
                    schedule('16 4-22 * * *', 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;
                                    for(let entry in data) {
                                        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'
                                        });
                                        if(existsState(idEnergie + time)) setState(idEnergie + time, data[entry][1], true);
                                        else createState(idEnergie + time, data[entry][1], {
                                            type: 'number', 
                                            role: 'value', 
                                            name: 'Solarenergie ' + formatDate(parseInt(entry), 'DD.MM. hh:mm'),
                                            read: true,
                                            write: false,
                                            unit: 'kWh'
                                        });
                                    }
                                }
                            }
                        });
                    });
                     
                    

                    Hat jemand hierzu eine Idee oder kann nochmal ein funktionierendes Script posten?

                    Danke,
                    Jens

                    GlasfaserG Offline
                    GlasfaserG Offline
                    Glasfaser
                    schrieb am zuletzt editiert von Glasfaser
                    #137

                    @docdan sagte in Solarprognose:

                    const url = 'http://www.solarprognose.de/web/solarprediction/api/v1?_format=json&access-token=78f1........ce0f&item=inverter&id=43..&type=hourly';

                    Wenn du die angegeben URL im Browser aufrufst ,ist dort ein -8 enthalten .

                    EDIT :

                    Nutze dieses nicht ....

                    aber bei den anderen hier im Thread sieht die URL anders am Ende aus !?

                    Synology 918+ 16GB - ioBroker in Docker v9 , VISO auf Trekstor Primebook C13 13,3" , Hikvision Domkameras mit Surveillance Station .. CCU RaspberryMatic in Synology VM .. Zigbee CC2538+CC2592 .. Sonoff .. KNX .. Modbus ..

                    DocdanD 1 Antwort Letzte Antwort
                    0
                    • GlasfaserG Glasfaser

                      @docdan sagte in Solarprognose:

                      const url = 'http://www.solarprognose.de/web/solarprediction/api/v1?_format=json&access-token=78f1........ce0f&item=inverter&id=43..&type=hourly';

                      Wenn du die angegeben URL im Browser aufrufst ,ist dort ein -8 enthalten .

                      EDIT :

                      Nutze dieses nicht ....

                      aber bei den anderen hier im Thread sieht die URL anders am Ende aus !?

                      DocdanD Online
                      DocdanD Online
                      Docdan
                      schrieb am zuletzt editiert von
                      #138

                      @glasfaser
                      Der Aufruf über die URL scheint zu klappen, da auf der Webseite von Solarprognose.de API Zugriffe registriert werden.

                      Irgendwie scheint JS mit der Response Funktion ein Problem zu haben.

                      1 Antwort Letzte Antwort
                      0
                      • DocdanD Online
                        DocdanD Online
                        Docdan
                        schrieb am zuletzt editiert von Docdan
                        #139

                        Ich habe mir die url nochmal angesehen, die war tatsächlich nicht ganz korrekt. Passt jetzt aber. Das Problem war die die Abrufzeit, da gibt die API bei mir eine Minute vor, in der abgerufen werden soll. Das passt jetzt auch. Die Objekte werden jetzt auch richtig angelegt, nur stehen keine Werte drin, nur 0? :worried:

                        Meister MopperM 1 Antwort Letzte Antwort
                        0
                        • DocdanD Docdan

                          Ich habe mir die url nochmal angesehen, die war tatsächlich nicht ganz korrekt. Passt jetzt aber. Das Problem war die die Abrufzeit, da gibt die API bei mir eine Minute vor, in der abgerufen werden soll. Das passt jetzt auch. Die Objekte werden jetzt auch richtig angelegt, nur stehen keine Werte drin, nur 0? :worried:

                          Meister MopperM Abwesend
                          Meister MopperM Abwesend
                          Meister Mopper
                          schrieb am zuletzt editiert von Meister Mopper
                          #140

                          @docdan sagte in Solarprognose:

                          Das Problem war die die Abrufzeit, da gibt die API bei mir eine Minute vor, in der abgerufen werden soll.

                          Wie hast du das im code gelöst? Die Vorgabe für die API ist bei mir Minute 7 mit einem sleep von 45 Sekunden.

                          38afa572-4ff2-4b25-822d-b7742994299a-grafik.png

                          Proxmox und HA

                          DocdanD 1 Antwort Letzte Antwort
                          0
                          • Meister MopperM Meister Mopper

                            @docdan sagte in Solarprognose:

                            Das Problem war die die Abrufzeit, da gibt die API bei mir eine Minute vor, in der abgerufen werden soll.

                            Wie hast du das im code gelöst? Die Vorgabe für die API ist bei mir Minute 7 mit einem sleep von 45 Sekunden.

                            38afa572-4ff2-4b25-822d-b7742994299a-grafik.png

                            DocdanD Online
                            DocdanD Online
                            Docdan
                            schrieb am zuletzt editiert von
                            #141

                            @meister-mopper

                            Ich habe auch Minute 7 und Sleep 39, Habe das genauso jetzt eingebaut, dann alle Datenpunkte nochmals gelöscht, jetzt läuft es einwandfrei.

                            Jetzt habe ich nur noch das Problem, die Daten in Grafana anzeigen zu können, ähnlich zu dem PV-Forecast Adapter :face_with_rolling_eyes:
                            Hat das jemand hinbekommen?

                            Meister MopperM 1 Antwort Letzte Antwort
                            0
                            • DocdanD Docdan

                              @meister-mopper

                              Ich habe auch Minute 7 und Sleep 39, Habe das genauso jetzt eingebaut, dann alle Datenpunkte nochmals gelöscht, jetzt läuft es einwandfrei.

                              Jetzt habe ich nur noch das Problem, die Daten in Grafana anzeigen zu können, ähnlich zu dem PV-Forecast Adapter :face_with_rolling_eyes:
                              Hat das jemand hinbekommen?

                              Meister MopperM Abwesend
                              Meister MopperM Abwesend
                              Meister Mopper
                              schrieb am zuletzt editiert von
                              #142

                              @docdan sagte in Solarprognose:

                              Habe das genauso jetzt eingebaut

                              Ja, das genau war meine Frage: Wie hast du es im Skript eingebaut?

                              Proxmox und HA

                              DocdanD 1 Antwort Letzte Antwort
                              0
                              • Meister MopperM Meister Mopper

                                @docdan sagte in Solarprognose:

                                Habe das genauso jetzt eingebaut

                                Ja, das genau war meine Frage: Wie hast du es im Skript eingebaut?

                                DocdanD Online
                                DocdanD Online
                                Docdan
                                schrieb am zuletzt editiert von Docdan
                                #143

                                @meister-mopper

                                So! Bisher läuft es!

                                schedule('7 4-22 * * *', function() { 
                                    sleep(39000)
                                    request(url, function (error, response, result)
                                
                                DocdanD arteckA 2 Antworten Letzte Antwort
                                0
                                • DocdanD Docdan

                                  @meister-mopper

                                  So! Bisher läuft es!

                                  schedule('7 4-22 * * *', function() { 
                                      sleep(39000)
                                      request(url, function (error, response, result)
                                  
                                  DocdanD Online
                                  DocdanD Online
                                  Docdan
                                  schrieb am zuletzt editiert von
                                  #144

                                  @docdan said in Solarprognose:

                                  @meister-mopper

                                  So! Bisher läuft es!

                                  schedule('7 4-22 * * *', function() { 
                                      sleep(39000)
                                      request(url, function (error, response, result)
                                  
                                  Meister MopperM 1 Antwort Letzte Antwort
                                  0
                                  • DocdanD Docdan

                                    @docdan said in Solarprognose:

                                    @meister-mopper

                                    So! Bisher läuft es!

                                    schedule('7 4-22 * * *', function() { 
                                        sleep(39000)
                                        request(url, function (error, response, result)
                                    
                                    Meister MopperM Abwesend
                                    Meister MopperM Abwesend
                                    Meister Mopper
                                    schrieb am zuletzt editiert von
                                    #145

                                    @docdan sagte in Solarprognose:

                                    @docdan said in Solarprognose:

                                    @meister-mopper

                                    So! Bisher läuft es!

                                    schedule('7 4-22 * * *', function() { 
                                        sleep(39000)
                                        request(url, function (error, response, result)
                                    

                                    Ich danke dir, das probier ich aus.

                                    Proxmox und HA

                                    DocdanD 1 Antwort Letzte Antwort
                                    0
                                    • Meister MopperM Meister Mopper

                                      @docdan sagte in Solarprognose:

                                      @docdan said in Solarprognose:

                                      @meister-mopper

                                      So! Bisher läuft es!

                                      schedule('7 4-22 * * *', function() { 
                                          sleep(39000)
                                          request(url, function (error, response, result)
                                      

                                      Ich danke dir, das probier ich aus.

                                      DocdanD Online
                                      DocdanD Online
                                      Docdan
                                      schrieb am zuletzt editiert von
                                      #146

                                      @meister-mopper

                                      So wie beschrieben funktioniert es nicht, leider!

                                      Habe es jetzt folgendermaßen abgeändert, das scheint erstmal zu klappen, werde es aber weiter beobachten:

                                      const path = '0_userdata.0.Solar.';
                                      
                                      const idLeistung = path + 'Leistung.';
                                      
                                      const idEnergie  = path + 'Energie.';
                                      
                                      function sleep(ms) {
                                        return new Promise(resolve => setTimeout(resolve, ms));
                                      }
                                      
                                      async function Waiting() {
                                        console.log('Going to sleep...');
                                        await sleep(39000); // Sleep for 39 seconds
                                        console.log('Done sleeping.');
                                      }
                                      
                                      schedule('7 4-22 * * *', function() { 
                                              
                                          Waiting();
                                      
                                          request(url, function (error, response, result) {
                                      
                                              if(error) log(error, 'error');```
                                      1 Antwort Letzte Antwort
                                      0
                                      • DocdanD Online
                                        DocdanD Online
                                        Docdan
                                        schrieb am zuletzt editiert von
                                        #147

                                        irgendwie funktioniert das alles nicht! Es wird zwar im Log eine Pause eingelegt aber im Hintergrund läuft das Script weiter.

                                        Ich habe jetzt alles wieder rausgenommen und mache die Abfrage nur in Minute 7. Ohne die Pause (bei mir sind 39 Sekunden vorgegeben).

                                        Das funktioniert soweit ohne Probleme.

                                        Hat jemand einen Tipp, wie ich die Datenpunkte in Grafana über InfluxDB in einem Diagramm darstellen kann. Wenn ich die Datenpunkte über den Influx Adapter in die Datenpunkte schreibe bekomme ich auch einen Datenpunkt in Grafana angezeigt, kann das aber nicht vernünftig in einem Diagramm darstellen. Ich möchte für jede Stunde den Letzten Wert in einem Timeline Chart darstellen, so wie in folgendem Bild.

                                        Bildschirmfoto 2024-02-18 um 18.08.08.png

                                        Hier kommen die Daten aber aus dem PVForecast Adapter und ich schaffe es einfach nicht, die Daten aus dem Script genauso darzustellen.

                                        Meister MopperM 1 Antwort Letzte Antwort
                                        0
                                        • DocdanD Docdan

                                          irgendwie funktioniert das alles nicht! Es wird zwar im Log eine Pause eingelegt aber im Hintergrund läuft das Script weiter.

                                          Ich habe jetzt alles wieder rausgenommen und mache die Abfrage nur in Minute 7. Ohne die Pause (bei mir sind 39 Sekunden vorgegeben).

                                          Das funktioniert soweit ohne Probleme.

                                          Hat jemand einen Tipp, wie ich die Datenpunkte in Grafana über InfluxDB in einem Diagramm darstellen kann. Wenn ich die Datenpunkte über den Influx Adapter in die Datenpunkte schreibe bekomme ich auch einen Datenpunkt in Grafana angezeigt, kann das aber nicht vernünftig in einem Diagramm darstellen. Ich möchte für jede Stunde den Letzten Wert in einem Timeline Chart darstellen, so wie in folgendem Bild.

                                          Bildschirmfoto 2024-02-18 um 18.08.08.png

                                          Hier kommen die Daten aber aus dem PVForecast Adapter und ich schaffe es einfach nicht, die Daten aus dem Script genauso darzustellen.

                                          Meister MopperM Abwesend
                                          Meister MopperM Abwesend
                                          Meister Mopper
                                          schrieb am zuletzt editiert von
                                          #148

                                          @docdan sagte in Solarprognose:

                                          irgendwie funktioniert das alles nicht! Es wird zwar im Log eine Pause eingelegt aber im Hintergrund läuft das Script weiter.

                                          Bei mir funktioniert es mit deiner Hilfe sehr gut und ich bekomme stündliche Prognosen.


                                          const path = '0_userdata.0.Energie.PV.Prognose.';
                                          const idLeistung = path + 'Leistung.';
                                          const idEnergie = path + 'Energie.';

                                          schedule('7 4-22 * * *', function() {
                                          sleep(45000)

                                          Die Daten kommen rein


                                          69856d3e-cddb-4b43-8bca-786c2f9aaa78-grafik.png

                                          @docdan sagte in Solarprognose:

                                          aber im Hintergrund läuft das Script weiter.

                                          Was meinst du damit, natürlich läuft das Script, solange es aktiviert ist?

                                          Proxmox und HA

                                          DocdanD 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

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

                                          735

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe