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.
  • B babl

    @paul53 alles gut, habe die komplette ordnerstruktur in den objekten gelöscht

    und nun schaut es gut aus, jetzt werden die Werte auch bestätigt. Keine Fehlermeldung mehr,

    ich hoffe das ist beim nächsten Durchlauf auch noch so.

    Ich danke euch beiden.

    paul53P Offline
    paul53P Offline
    paul53
    schrieb am zuletzt editiert von paul53
    #115

    @babl
    Du hast das falsche Skript gepostet. Wahrscheinlich verwendest Du dieses hier. Dann füge im setState() hinten ein ,true an (Zeilen 21 und 30).

    @babl sagte in Solarprognose:

    ich hoffe das ist beim nächsten Durchlauf auch noch so.

    Nur, wenn Du die beiden setState() änderst. Beim ersten Durchlauf wurden createState() ausgeführt.

    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

    B 1 Antwort Letzte Antwort
    0
    • paul53P paul53

      @babl
      Du hast das falsche Skript gepostet. Wahrscheinlich verwendest Du dieses hier. Dann füge im setState() hinten ein ,true an (Zeilen 21 und 30).

      @babl sagte in Solarprognose:

      ich hoffe das ist beim nächsten Durchlauf auch noch so.

      Nur, wenn Du die beiden setState() änderst. Beim ersten Durchlauf wurden createState() ausgeführt.

      B Offline
      B Offline
      babl
      schrieb am zuletzt editiert von babl
      #116

      @paul53

      const url = 'http://www.solarprognose.de/web/solarprediction/api/v1?_format=json&access-token=;
      const path = '0_userdata.0.Solar.';
      
      const idLeistung = path + 'Leistung.';
      
      const idEnergie  = path + 'Energie.';
      
       
      
      schedule('16 5-20 * * *', 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;
      
                      let wdHeute = new Date().getDay();
      
                      for(let entry in data) {
      
                          let wd = new Date(1000 * parseInt(entry)).getDay();
      
                          let time = formatDate(parseInt(entry), 'hh:mm');
      
                          if(wd == wdHeute) time = 'heute_' + time;
      
                          else time = 'morgen_' + time;
      
                          if(existsState(idLeistung + time)) setState(idLeistung + time, data[entry][0]);
      
                          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]);
      
                          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'
      
                          });
      
                      }
      
                  }
      
              }
      
          });
      
      });
      

      Das hier ist das Script

      und wo muß ich da das true anfügen? so?

       if(existsState(idLeistung + time)) setState(idLeistung + time, data[entry][0]); true
      
      paul53P 1 Antwort Letzte Antwort
      0
      • B babl

        @paul53

        const url = 'http://www.solarprognose.de/web/solarprediction/api/v1?_format=json&access-token=;
        const path = '0_userdata.0.Solar.';
        
        const idLeistung = path + 'Leistung.';
        
        const idEnergie  = path + 'Energie.';
        
         
        
        schedule('16 5-20 * * *', 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;
        
                        let wdHeute = new Date().getDay();
        
                        for(let entry in data) {
        
                            let wd = new Date(1000 * parseInt(entry)).getDay();
        
                            let time = formatDate(parseInt(entry), 'hh:mm');
        
                            if(wd == wdHeute) time = 'heute_' + time;
        
                            else time = 'morgen_' + time;
        
                            if(existsState(idLeistung + time)) setState(idLeistung + time, data[entry][0]);
        
                            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]);
        
                            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'
        
                            });
        
                        }
        
                    }
        
                }
        
            });
        
        });
        

        Das hier ist das Script

        und wo muß ich da das true anfügen? so?

         if(existsState(idLeistung + time)) setState(idLeistung + time, data[entry][0]); true
        
        paul53P Offline
        paul53P Offline
        paul53
        schrieb am zuletzt editiert von paul53
        #117

        @babl sagte: wo muß ich da das true anfügen?

                            if(existsState(idLeistung + time)) setState(idLeistung + time, data[entry][0], true);
        

        und

                            if(existsState(idEnergie + time)) setState(idEnergie + time, data[entry][1], true);
        

        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

        B 1 Antwort Letzte Antwort
        1
        • paul53P paul53

          @babl sagte: wo muß ich da das true anfügen?

                              if(existsState(idLeistung + time)) setState(idLeistung + time, data[entry][0], true);
          

          und

                              if(existsState(idEnergie + time)) setState(idEnergie + time, data[entry][1], true);
          
          B Offline
          B Offline
          babl
          schrieb am zuletzt editiert von
          #118

          @paul53 danke dir

          1 Antwort Letzte Antwort
          0
          • O Offline
            O Offline
            Orbitson
            schrieb am zuletzt editiert von
            #119

            @paul53 @babl
            Echt super Anleitung konnte das dank euch schnell und einfach um setzen aber wie habt ihr das in ein Diagramm umgesetzt? Via History funktioniert das ja nicht…

            Mit sonnigen Grüßen

            B 1 Antwort Letzte Antwort
            0
            • O Orbitson

              @paul53 @babl
              Echt super Anleitung konnte das dank euch schnell und einfach um setzen aber wie habt ihr das in ein Diagramm umgesetzt? Via History funktioniert das ja nicht…

              Mit sonnigen Grüßen

              B Offline
              B Offline
              babl
              schrieb am zuletzt editiert von
              #120

              @orbitson hi danke dir, ich hab nur die tagesenergie für den heutigen Tag und den morgigen als datenpunkt auf der vis abgebildet so hat man ungefähr eine Ahnung was rauskommen soll.

              1 Antwort Letzte Antwort
              0
              • M Offline
                M Offline
                Marc_St
                schrieb am zuletzt editiert von
                #121

                Liebe alle, zunächst danke für die Diskussionen hier. Steigt man später mit dem Thema ein, ist so etwas ungemein praktisch.

                Ich habe zwei Fragen:

                1.) Wie genau ist bei Euch die Vorhersage? Ich habe zwei Modulfelder präzise auf der Seite angelegt, korrekten Temperatur-Koeffizient, Neigung, Ausrichtung ... sogar die Verschattung hatte ich aus einer Horizont-Datei mit PVGIS und etwas EXCEL berechnen können. Allzu genau scheinen mir aber die vorhersagen nicht zu sein. Eher noch die Tageserträge, aber die stündlichen Leistungswerte wären natürlich hilfreicher, wenn sie genauer wären. Eine MOSMIX-Station habe ich sogar ganz in der Nähe.

                Ich überlege, einmal die tatsächlichen Werte der Anlage über die Prognose zu legen. Hat das schon jemand fertig zur Hand?

                2.) Was macht Ihr eigentlich mit der Prognose? Abstrakt würde ich etwa sehen, ob es lohnt (oder auch nur überhaupt möglich ist), mein E-Fahrzeug zu laden. Schön und gut, aber das macht die OpenWB ohnehin on Demand. Was könnte man sonst noch machen? Morgens der Regierung die Waschmaschine sperren, weil in zwei Stunden (aber noch nicht aktuell) genug PV-Vertrag vorhanden ist? Der WAF wäre wohl sehr gering, und dann kommt es ja auch sehr auf die individuellen Möglichkeiten solcher Verbraucher an. Was meint Ihr?

                LG!

                Johannes BauerstatterJ T 2 Antworten Letzte Antwort
                0
                • M Marc_St

                  Liebe alle, zunächst danke für die Diskussionen hier. Steigt man später mit dem Thema ein, ist so etwas ungemein praktisch.

                  Ich habe zwei Fragen:

                  1.) Wie genau ist bei Euch die Vorhersage? Ich habe zwei Modulfelder präzise auf der Seite angelegt, korrekten Temperatur-Koeffizient, Neigung, Ausrichtung ... sogar die Verschattung hatte ich aus einer Horizont-Datei mit PVGIS und etwas EXCEL berechnen können. Allzu genau scheinen mir aber die vorhersagen nicht zu sein. Eher noch die Tageserträge, aber die stündlichen Leistungswerte wären natürlich hilfreicher, wenn sie genauer wären. Eine MOSMIX-Station habe ich sogar ganz in der Nähe.

                  Ich überlege, einmal die tatsächlichen Werte der Anlage über die Prognose zu legen. Hat das schon jemand fertig zur Hand?

                  2.) Was macht Ihr eigentlich mit der Prognose? Abstrakt würde ich etwa sehen, ob es lohnt (oder auch nur überhaupt möglich ist), mein E-Fahrzeug zu laden. Schön und gut, aber das macht die OpenWB ohnehin on Demand. Was könnte man sonst noch machen? Morgens der Regierung die Waschmaschine sperren, weil in zwei Stunden (aber noch nicht aktuell) genug PV-Vertrag vorhanden ist? Der WAF wäre wohl sehr gering, und dann kommt es ja auch sehr auf die individuellen Möglichkeiten solcher Verbraucher an. Was meint Ihr?

                  LG!

                  Johannes BauerstatterJ Offline
                  Johannes BauerstatterJ Offline
                  Johannes Bauerstatter
                  schrieb am zuletzt editiert von
                  #122

                  @marc_st Hi, ich hab mir einen 12kW Batteriespeicher gebaut und 2 E-Autos. Da könnte man anhand der Prognose die idealen Ladeeinstellung vorprogrammieren. Ich hab das Thema gerade erst gefunden und werd mir das mal anschauen, was hier zu bekommen ist. Ich bräuchte eigentlich nur für 1-2 Tag in die Zukunft wann und wieviele Sonnenstunden zu erwarten sind.

                  1 Antwort Letzte Antwort
                  0
                  • M Marc_St

                    Liebe alle, zunächst danke für die Diskussionen hier. Steigt man später mit dem Thema ein, ist so etwas ungemein praktisch.

                    Ich habe zwei Fragen:

                    1.) Wie genau ist bei Euch die Vorhersage? Ich habe zwei Modulfelder präzise auf der Seite angelegt, korrekten Temperatur-Koeffizient, Neigung, Ausrichtung ... sogar die Verschattung hatte ich aus einer Horizont-Datei mit PVGIS und etwas EXCEL berechnen können. Allzu genau scheinen mir aber die vorhersagen nicht zu sein. Eher noch die Tageserträge, aber die stündlichen Leistungswerte wären natürlich hilfreicher, wenn sie genauer wären. Eine MOSMIX-Station habe ich sogar ganz in der Nähe.

                    Ich überlege, einmal die tatsächlichen Werte der Anlage über die Prognose zu legen. Hat das schon jemand fertig zur Hand?

                    2.) Was macht Ihr eigentlich mit der Prognose? Abstrakt würde ich etwa sehen, ob es lohnt (oder auch nur überhaupt möglich ist), mein E-Fahrzeug zu laden. Schön und gut, aber das macht die OpenWB ohnehin on Demand. Was könnte man sonst noch machen? Morgens der Regierung die Waschmaschine sperren, weil in zwei Stunden (aber noch nicht aktuell) genug PV-Vertrag vorhanden ist? Der WAF wäre wohl sehr gering, und dann kommt es ja auch sehr auf die individuellen Möglichkeiten solcher Verbraucher an. Was meint Ihr?

                    LG!

                    T Online
                    T Online
                    tobi19
                    schrieb am zuletzt editiert von
                    #123

                    Hallo
                    @marc_st sagte in Solarprognose:

                    1.) Wie genau ist bei Euch die Vorhersage?

                    nach meiner Erfahrung ist hier mit +/- 50% jederzeit zu rechnen.
                    Eine Stundenbasierte Prognose halte ich für nicht möglich.

                    2.) Was macht Ihr eigentlich mit der Prognose?

                    Ich verwende sie um bei meiner Akku-Ladestrategie eine grobe Fallunterscheidung zu machen:
                    a) alles hamstern und b) netzdienlich über die Spitzenzeit zu laden
                    Auch wird meine Warmwasser-WP bei hoher Prognose in den 65° Modus gesetzt.

                    Meine Frau entscheidet, ob heute Waschtag ist oder besser nicht.

                    LG

                    D 1 Antwort Letzte Antwort
                    0
                    • T tobi19

                      Hallo
                      @marc_st sagte in Solarprognose:

                      1.) Wie genau ist bei Euch die Vorhersage?

                      nach meiner Erfahrung ist hier mit +/- 50% jederzeit zu rechnen.
                      Eine Stundenbasierte Prognose halte ich für nicht möglich.

                      2.) Was macht Ihr eigentlich mit der Prognose?

                      Ich verwende sie um bei meiner Akku-Ladestrategie eine grobe Fallunterscheidung zu machen:
                      a) alles hamstern und b) netzdienlich über die Spitzenzeit zu laden
                      Auch wird meine Warmwasser-WP bei hoher Prognose in den 65° Modus gesetzt.

                      Meine Frau entscheidet, ob heute Waschtag ist oder besser nicht.

                      LG

                      D Offline
                      D Offline
                      Diamand2k22
                      schrieb am zuletzt editiert von Diamand2k22
                      #124

                      @paul53

                      Hallo Paul, vielleicht kannst du mir helfen, du hast ja damals sehr stark bei dem Skript mitgewirk.
                      Ich habe das Problem, dass mir als Forecast für den nächsten Tag der Wert von in 4 Tagen auf den Datenpunkt geschrieben wird,
                      als Beispiel, heute der 26.08 -> Prognosewert heute stimmt mit Wert von Solarprognose.de überein, allerdings steht bei Prognosewert für morgen der vom 30.08. drin.
                      an was könnte das liegen?

                      Hier das Skript:

                      const url = 'https://www.solarprognose.de/web/solarprediction/api/v1?_format=json&access-token=xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx&&type=hourly&algorithm=mosmix';
                      const path = '0_userdata.0.Datenpunkte.PV_Anlage.Solarforecast.';
                      const idLeistung_Energie = path + 'Leistung_Energie';
                      const idEnergieMaxHeute = path + 'EnergieMaxHeute';
                      const idEnergieMaxHeute_Remaining = path + 'EnergieMaxHeute_Remaining';
                      const idEnergieMaxMorgen = path + 'EnergieMaxMorgen';
                      const idLeistung = path + 'Leistung.';
                      const idEnergie  = path + 'Energie.';
                       
                      var Leistung_Energie = {
                          "axisLabels": ["8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18","19", "20", "21","22", "8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18","19", "20", "21", "22"],
                          "graphs": [{
                              "data": [0, 0, 0, 0, 0, 0, 0, 0, 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": 15,
                              "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, 0, 0, 0, 0, 0, 0, 0, 0],
                              "type": "line",
                              "line_UseFillColor": true,
                              "legendText":"Energie",
                              "yAxis_min": 0,
                              "yAxis_max": 74,
                              "yAxis_step": 15,
                              "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(idEnergieMaxHeute_Remaining, 0, {type: 'number', role: 'value', name: 'EnergieMaxHeute_Remaining', read: true, write: false, unit: 'kWh'});
                      createState(idEnergieMaxMorgen, 0, {type: 'number', role: 'value', name: 'EnergieMaxMorgen', read: true, write: false, unit: 'kWh'});
                       
                      schedule('44 30 */1 * * *', 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 == '22')
                                             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);                 
                                      for(let entry in data) {
                      
                                          let wdHeute = new Date().getDay();
                      
                                          let wd = new Date(1000 * parseInt(entry)).getDay();
                      
                                          let time = formatDate(parseInt(entry), 'hh_mm');
                      
                                          if(wd == wdHeute) time = 'heute_' + time;
                      
                                          else time = 'morgen_' + time;
                      
                                          
                                          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'
                      
                                          });
                      
                                      }           
                                  }
                              }
                          });
                      });
                      schedule('55 30 */1 * * *', function() { 
                      setState(idEnergieMaxHeute_Remaining, (getState(idEnergieMaxHeute).val - getState("0_userdata.0.Datenpunkte.PV_Anlage.Solarweb.Current.01_Day.Energy.EnergyProductionTotal").val), true); 
                      });
                      
                      paul53P 1 Antwort Letzte Antwort
                      0
                      • HomoranH Homoran

                        @paul53 sagte in Solarprognose:

                        Etwas Erfahrung gehört schon dazu.

                        Die Untertreibung des Jahrhunderts ! ;-)

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

                        @homoran sagte in Solarprognose:

                        Die Untertreibung des Jahrhunderts !

                        Und das ist noch jung! :blush:

                        Proxmox und HA

                        1 Antwort Letzte Antwort
                        0
                        • D Diamand2k22

                          @paul53

                          Hallo Paul, vielleicht kannst du mir helfen, du hast ja damals sehr stark bei dem Skript mitgewirk.
                          Ich habe das Problem, dass mir als Forecast für den nächsten Tag der Wert von in 4 Tagen auf den Datenpunkt geschrieben wird,
                          als Beispiel, heute der 26.08 -> Prognosewert heute stimmt mit Wert von Solarprognose.de überein, allerdings steht bei Prognosewert für morgen der vom 30.08. drin.
                          an was könnte das liegen?

                          Hier das Skript:

                          const url = 'https://www.solarprognose.de/web/solarprediction/api/v1?_format=json&access-token=xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx&&type=hourly&algorithm=mosmix';
                          const path = '0_userdata.0.Datenpunkte.PV_Anlage.Solarforecast.';
                          const idLeistung_Energie = path + 'Leistung_Energie';
                          const idEnergieMaxHeute = path + 'EnergieMaxHeute';
                          const idEnergieMaxHeute_Remaining = path + 'EnergieMaxHeute_Remaining';
                          const idEnergieMaxMorgen = path + 'EnergieMaxMorgen';
                          const idLeistung = path + 'Leistung.';
                          const idEnergie  = path + 'Energie.';
                           
                          var Leistung_Energie = {
                              "axisLabels": ["8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18","19", "20", "21","22", "8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18","19", "20", "21", "22"],
                              "graphs": [{
                                  "data": [0, 0, 0, 0, 0, 0, 0, 0, 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": 15,
                                  "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, 0, 0, 0, 0, 0, 0, 0, 0],
                                  "type": "line",
                                  "line_UseFillColor": true,
                                  "legendText":"Energie",
                                  "yAxis_min": 0,
                                  "yAxis_max": 74,
                                  "yAxis_step": 15,
                                  "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(idEnergieMaxHeute_Remaining, 0, {type: 'number', role: 'value', name: 'EnergieMaxHeute_Remaining', read: true, write: false, unit: 'kWh'});
                          createState(idEnergieMaxMorgen, 0, {type: 'number', role: 'value', name: 'EnergieMaxMorgen', read: true, write: false, unit: 'kWh'});
                           
                          schedule('44 30 */1 * * *', 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 == '22')
                                                 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);                 
                                          for(let entry in data) {
                          
                                              let wdHeute = new Date().getDay();
                          
                                              let wd = new Date(1000 * parseInt(entry)).getDay();
                          
                                              let time = formatDate(parseInt(entry), 'hh_mm');
                          
                                              if(wd == wdHeute) time = 'heute_' + time;
                          
                                              else time = 'morgen_' + time;
                          
                                              
                                              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'
                          
                                              });
                          
                                          }           
                                      }
                                  }
                              });
                          });
                          schedule('55 30 */1 * * *', function() { 
                          setState(idEnergieMaxHeute_Remaining, (getState(idEnergieMaxHeute).val - getState("0_userdata.0.Datenpunkte.PV_Anlage.Solarweb.Current.01_Day.Energy.EnergyProductionTotal").val), true); 
                          });
                          
                          paul53P Offline
                          paul53P Offline
                          paul53
                          schrieb am zuletzt editiert von
                          #126

                          @diamand2k22
                          Was soll in Zeilen 61 bis 63 passieren?

                          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
                            Was soll in Zeilen 61 bis 63 passieren?

                            D Offline
                            D Offline
                            Diamand2k22
                            schrieb am zuletzt editiert von
                            #127

                            @paul53

                            prinzipiell habe ich das Skript von oben übernommen.
                            da war der Code schon so drin aber mit Abfrage auf ==19 Uhr. Ich habe das aufgebohrt auf 22 Uhr da ich die Daten von Solarprognose.de von 8 Uhr bis 22 Uhr erhalte.

                            {
                              "axisLabels": [
                                "08",
                                "09",
                                "10",
                                "11",
                                "12",
                                "13",
                                "14",
                                "15",
                                "16",
                                "17",
                                "18",
                                "19",
                                "20",
                                "21",
                                "22",
                                "08",
                                "09",
                                "10",
                                "11",
                                "12",
                                "13",
                                "14",
                                "15",
                                "16",
                                "17",
                                "18",
                                "19",
                                "20",
                                "21",
                                "22",
                                "08",
                                "09",
                                "10",
                                "11",
                                "12",
                                "13",
                                "14",
                                "15",
                                "16",
                                "17",
                                "18",
                                "19",
                                "20",
                                "21",
                                "22",
                                "08",
                                "09",
                                "10",
                                "11",
                                "12",
                                "13",
                                "14",
                                "15",
                                "16",
                                "17",
                                "18",
                                "19",
                                "20",
                                "21",
                                "22",
                                "08",
                                "09",
                                "10",
                                "11",
                                "12",
                                "13",
                                "14",
                                "15",
                                "16",
                                "17",
                                "18",
                                "19",
                                "20",
                                "21",
                                "22"
                              ],
                              "graphs": [
                                {
                                  "data": [
                                    0,
                                    0.04,
                                    0.598,
                                    1.817,
                                    3.468,
                                    5.071,
                                    6.555,
                                    8.452,
                                    8.565,
                                    8.253,
                                    6.642,
                                    4.723,
                                    2.512,
                                    1.267,
                                    0,
                                    0,
                                    0.041,
                                    0.417,
                                    1.272,
                                    2.049,
                                    2.735,
                                    2.967,
                                    3.405,
                                    2.915,
                                    2.809,
                                    2.557,
                                    1.949,
                                    1.178,
                                    0.609,
                                    0,
                                    0,
                                    0.041,
                                    0.282,
                                    0.62,
                                    1.04,
                                    1.418,
                                    1.855,
                                    2.448,
                                    2.466,
                                    2.665,
                                    2.14,
                                    1.515,
                                    1.26,
                                    0.959,
                                    0,
                                    0,
                                    0.041,
                                    0.424,
                                    1.295,
                                    2.473,
                                    4.092,
                                    4.998,
                                    5.924,
                                    5.251,
                                    5.452,
                                    5.186,
                                    4.407,
                                    3.639,
                                    2.261,
                                    0,
                                    0,
                                    0.083,
                                    0.756,
                                    2.382,
                                    4.644,
                                    6.878,
                                    8.278,
                                    9.806,
                                    10.782,
                                    10.498,
                                    9.438,
                                    7.122,
                                    5.021,
                                    2.901,
                                    0
                                  ],
                                  "type": "line",
                                  "legendText": "Leistung",
                                  "yAxis_min": 0,
                                  "yAxis_max": 15,
                                  "yAxis_step": 1,
                                  "yAxis_position": "left",
                                  "yAxis_appendix": " kW",
                                  "datalabel_show": false
                                },
                                {
                                  "data": [
                                    0,
                                    0.04,
                                    0.638,
                                    2.455,
                                    5.923,
                                    10.994,
                                    17.549,
                                    26.001,
                                    34.566,
                                    42.819,
                                    49.461,
                                    54.184,
                                    56.696,
                                    57.963,
                                    57.963,
                                    0,
                                    0.041,
                                    0.458,
                                    1.73,
                                    3.779,
                                    6.514,
                                    9.481,
                                    12.886,
                                    15.801,
                                    18.61,
                                    21.167,
                                    23.116,
                                    24.294,
                                    24.903,
                                    24.903,
                                    0,
                                    0.041,
                                    0.323,
                                    0.943,
                                    1.983,
                                    3.401,
                                    5.256,
                                    7.704,
                                    10.17,
                                    12.835,
                                    14.975,
                                    16.49,
                                    17.75,
                                    18.709,
                                    18.709,
                                    0,
                                    0.041,
                                    0.465,
                                    1.76,
                                    4.233,
                                    8.325,
                                    13.323,
                                    19.247,
                                    24.498,
                                    29.95,
                                    35.136,
                                    39.543,
                                    43.182,
                                    45.443,
                                    45.443,
                                    0,
                                    0.083,
                                    0.839,
                                    3.221,
                                    7.865,
                                    14.743,
                                    23.021,
                                    32.827,
                                    43.609,
                                    54.107,
                                    63.545,
                                    70.667,
                                    75.688,
                                    78.589,
                                    78.589
                                  ],
                                  "type": "line",
                                  "line_UseFillColor": true,
                                  "legendText": "Energie",
                                  "yAxis_min": 0,
                                  "yAxis_max": 74,
                                  "yAxis_step": 15,
                                  "yAxis_position": "right",
                                  "yAxis_appendix": " kWh",
                                  "yAxis_color": "#91d430",
                                  "datalabel_show": false
                                }
                              ]
                            }
                            
                            paul53P 1 Antwort Letzte Antwort
                            0
                            • D Diamand2k22

                              @paul53

                              prinzipiell habe ich das Skript von oben übernommen.
                              da war der Code schon so drin aber mit Abfrage auf ==19 Uhr. Ich habe das aufgebohrt auf 22 Uhr da ich die Daten von Solarprognose.de von 8 Uhr bis 22 Uhr erhalte.

                              {
                                "axisLabels": [
                                  "08",
                                  "09",
                                  "10",
                                  "11",
                                  "12",
                                  "13",
                                  "14",
                                  "15",
                                  "16",
                                  "17",
                                  "18",
                                  "19",
                                  "20",
                                  "21",
                                  "22",
                                  "08",
                                  "09",
                                  "10",
                                  "11",
                                  "12",
                                  "13",
                                  "14",
                                  "15",
                                  "16",
                                  "17",
                                  "18",
                                  "19",
                                  "20",
                                  "21",
                                  "22",
                                  "08",
                                  "09",
                                  "10",
                                  "11",
                                  "12",
                                  "13",
                                  "14",
                                  "15",
                                  "16",
                                  "17",
                                  "18",
                                  "19",
                                  "20",
                                  "21",
                                  "22",
                                  "08",
                                  "09",
                                  "10",
                                  "11",
                                  "12",
                                  "13",
                                  "14",
                                  "15",
                                  "16",
                                  "17",
                                  "18",
                                  "19",
                                  "20",
                                  "21",
                                  "22",
                                  "08",
                                  "09",
                                  "10",
                                  "11",
                                  "12",
                                  "13",
                                  "14",
                                  "15",
                                  "16",
                                  "17",
                                  "18",
                                  "19",
                                  "20",
                                  "21",
                                  "22"
                                ],
                                "graphs": [
                                  {
                                    "data": [
                                      0,
                                      0.04,
                                      0.598,
                                      1.817,
                                      3.468,
                                      5.071,
                                      6.555,
                                      8.452,
                                      8.565,
                                      8.253,
                                      6.642,
                                      4.723,
                                      2.512,
                                      1.267,
                                      0,
                                      0,
                                      0.041,
                                      0.417,
                                      1.272,
                                      2.049,
                                      2.735,
                                      2.967,
                                      3.405,
                                      2.915,
                                      2.809,
                                      2.557,
                                      1.949,
                                      1.178,
                                      0.609,
                                      0,
                                      0,
                                      0.041,
                                      0.282,
                                      0.62,
                                      1.04,
                                      1.418,
                                      1.855,
                                      2.448,
                                      2.466,
                                      2.665,
                                      2.14,
                                      1.515,
                                      1.26,
                                      0.959,
                                      0,
                                      0,
                                      0.041,
                                      0.424,
                                      1.295,
                                      2.473,
                                      4.092,
                                      4.998,
                                      5.924,
                                      5.251,
                                      5.452,
                                      5.186,
                                      4.407,
                                      3.639,
                                      2.261,
                                      0,
                                      0,
                                      0.083,
                                      0.756,
                                      2.382,
                                      4.644,
                                      6.878,
                                      8.278,
                                      9.806,
                                      10.782,
                                      10.498,
                                      9.438,
                                      7.122,
                                      5.021,
                                      2.901,
                                      0
                                    ],
                                    "type": "line",
                                    "legendText": "Leistung",
                                    "yAxis_min": 0,
                                    "yAxis_max": 15,
                                    "yAxis_step": 1,
                                    "yAxis_position": "left",
                                    "yAxis_appendix": " kW",
                                    "datalabel_show": false
                                  },
                                  {
                                    "data": [
                                      0,
                                      0.04,
                                      0.638,
                                      2.455,
                                      5.923,
                                      10.994,
                                      17.549,
                                      26.001,
                                      34.566,
                                      42.819,
                                      49.461,
                                      54.184,
                                      56.696,
                                      57.963,
                                      57.963,
                                      0,
                                      0.041,
                                      0.458,
                                      1.73,
                                      3.779,
                                      6.514,
                                      9.481,
                                      12.886,
                                      15.801,
                                      18.61,
                                      21.167,
                                      23.116,
                                      24.294,
                                      24.903,
                                      24.903,
                                      0,
                                      0.041,
                                      0.323,
                                      0.943,
                                      1.983,
                                      3.401,
                                      5.256,
                                      7.704,
                                      10.17,
                                      12.835,
                                      14.975,
                                      16.49,
                                      17.75,
                                      18.709,
                                      18.709,
                                      0,
                                      0.041,
                                      0.465,
                                      1.76,
                                      4.233,
                                      8.325,
                                      13.323,
                                      19.247,
                                      24.498,
                                      29.95,
                                      35.136,
                                      39.543,
                                      43.182,
                                      45.443,
                                      45.443,
                                      0,
                                      0.083,
                                      0.839,
                                      3.221,
                                      7.865,
                                      14.743,
                                      23.021,
                                      32.827,
                                      43.609,
                                      54.107,
                                      63.545,
                                      70.667,
                                      75.688,
                                      78.589,
                                      78.589
                                    ],
                                    "type": "line",
                                    "line_UseFillColor": true,
                                    "legendText": "Energie",
                                    "yAxis_min": 0,
                                    "yAxis_max": 74,
                                    "yAxis_step": 15,
                                    "yAxis_position": "right",
                                    "yAxis_appendix": " kWh",
                                    "yAxis_color": "#91d430",
                                    "datalabel_show": false
                                  }
                                ]
                              }
                              
                              paul53P Offline
                              paul53P Offline
                              paul53
                              schrieb am zuletzt editiert von
                              #128

                              @diamand2k22 sagte: das Skript von oben

                              Welches?
                              Du hast Daten von 5 Tagen.

                              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

                              1 Antwort Letzte Antwort
                              0
                              • 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
                                          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

                                          573

                                          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