Navigation

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

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Solarprognose

    This topic has been deleted. Only users with topic management privileges can see it.
    • B
      babl @Orbitson last edited by

      @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 Reply Last reply Reply Quote 0
      • M
        Marc_St last edited by

        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 Bauerstatter T 2 Replies Last reply Reply Quote 0
        • Johannes Bauerstatter
          Johannes Bauerstatter @Marc_St last edited by

          @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 Reply Last reply Reply Quote 0
          • T
            tobi19 @Marc_St last edited by

            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 Reply Last reply Reply Quote 0
            • D
              Diamand2k22 @tobi19 last edited by 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); 
              });
              
              paul53 1 Reply Last reply Reply Quote 0
              • Meister Mopper
                Meister Mopper @Homoran last edited by

                @homoran sagte in Solarprognose:

                Die Untertreibung des Jahrhunderts !

                Und das ist noch jung! 😊

                1 Reply Last reply Reply Quote 0
                • paul53
                  paul53 @Diamand2k22 last edited by

                  @diamand2k22
                  Was soll in Zeilen 61 bis 63 passieren?

                  D 1 Reply Last reply Reply Quote 0
                  • D
                    Diamand2k22 @paul53 last edited by

                    @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
                        }
                      ]
                    }
                    
                    paul53 1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 @Diamand2k22 last edited by

                      @diamand2k22 sagte: das Skript von oben

                      Welches?
                      Du hast Daten von 5 Tagen.

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

                        @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);               
                                    }
                                }
                            });
                        });
                         
                        
                        
                        paul53 1 Reply Last reply Reply Quote 0
                        • paul53
                          paul53 @Diamand2k22 last edited by 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 1 Reply Last reply Reply Quote 0
                          • D
                            Diamand2k22 @paul53 last edited by

                            @paul53

                            das hat funktioniert, danke!

                            S 1 Reply Last reply Reply Quote 0
                            • S
                              SkeeveKlah @Diamand2k22 last edited by

                              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 1 Reply Last reply Reply Quote 0
                              • D
                                drdoener last edited by

                                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 Reply Last reply Reply Quote 0
                                • D
                                  drdoener @SkeeveKlah last edited by

                                  @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 Reply Last reply Reply Quote 0
                                  • Docdan
                                    Docdan last edited by 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

                                    Glasfaser 1 Reply Last reply Reply Quote 0
                                    • Docdan
                                      Docdan last edited by

                                      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 Reply Last reply Reply Quote 0
                                      • Glasfaser
                                        Glasfaser @Docdan last edited by 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 !?

                                        Docdan 1 Reply Last reply Reply Quote 0
                                        • Docdan
                                          Docdan @Glasfaser last edited by

                                          @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 Reply Last reply Reply Quote 0
                                          • Docdan
                                            Docdan last edited by 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? 😟

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

                                            Support us

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

                                            839
                                            Online

                                            31.8k
                                            Users

                                            79.9k
                                            Topics

                                            1.3m
                                            Posts

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