Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

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

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    2.9k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.1k

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.4k

Solarprognose

Scheduled Pinned Locked Moved ioBroker Allgemein
solarprognoseadapterjavascript
157 Posts 27 Posters 29.7k Views 30 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • 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
    wrote on last edited by 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 Reply Last reply
    0
    • HomoranH Homoran

      @paul53 sagte in Solarprognose:

      Etwas Erfahrung gehört schon dazu.

      Die Untertreibung des Jahrhunderts ! ;-)

      Meister MopperM Online
      Meister MopperM Online
      Meister Mopper
      wrote on last edited by
      #125

      @homoran sagte in Solarprognose:

      Die Untertreibung des Jahrhunderts !

      Und das ist noch jung! :blush:

      Proxmox und HA

      1 Reply Last reply
      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
        wrote on last edited by
        #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 Reply Last reply
        0
        • paul53P paul53

          @diamand2k22
          Was soll in Zeilen 61 bis 63 passieren?

          D Offline
          D Offline
          Diamand2k22
          wrote on last edited by
          #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 Reply Last reply
          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
            wrote on last edited by
            #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 Reply Last reply
            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
              wrote on last edited by
              #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 Reply Last reply
              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
                wrote on last edited by 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 Reply Last reply
                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
                  wrote on last edited by
                  #131

                  @paul53

                  das hat funktioniert, danke!

                  S 1 Reply Last reply
                  0
                  • D Diamand2k22

                    @paul53

                    das hat funktioniert, danke!

                    S Offline
                    S Offline
                    SkeeveKlah
                    wrote on last edited by
                    #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 Reply Last reply
                    0
                    • D Offline
                      D Offline
                      drdoener
                      wrote on last edited by
                      #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 Reply Last reply
                      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
                        wrote on last edited by
                        #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 Reply Last reply
                        0
                        • DocdanD Offline
                          DocdanD Offline
                          Docdan
                          wrote on last edited by Docdan
                          #135

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

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

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

                          Hier der code den ich benutze:

                          const url = 'http://www.solarprognose.de/web/solarprediction/api/v1?_format=json&access-token=78f1........ce0f&item=inverter&id=43..&type=hourly';
                          const path = '0_userdata.0.Solar.';
                          const idLeistung = path + 'Leistung.';
                          const idEnergie  = path + 'Energie.';
                           
                          schedule('16 4-22 * * *', function() { 
                              request(url, function (error, response, result) {
                                  if(error) log(error, 'error');
                                  else {
                                      let obj = JSON.parse(result);
                                      if(obj.status) log('Fehler: ' + obj.status, 'warn');
                                      else {
                                          let data = obj.data;
                                          for(let entry in data) {
                                              let time = formatDate(parseInt(entry), 'MM-DD.hh:mm');
                                              if(existsState(idLeistung + time)) setState(idLeistung + time, data[entry][0], true);
                                              else createState(idLeistung + time, data[entry][0], {
                                                  type: 'number', 
                                                  role: 'value', 
                                                  name: 'Solarleistung ' + formatDate(parseInt(entry), 'DD.MM. hh:mm'),
                                                  read: true,
                                                  write: false,
                                                  unit: 'kW'
                                              });
                                              if(existsState(idEnergie + time)) setState(idEnergie + time, data[entry][1], true);
                                              else createState(idEnergie + time, data[entry][1], {
                                                  type: 'number', 
                                                  role: 'value', 
                                                  name: 'Solarenergie ' + formatDate(parseInt(entry), 'DD.MM. hh:mm'),
                                                  read: true,
                                                  write: false,
                                                  unit: 'kWh'
                                              });
                                          }
                                      }
                                  }
                              });
                          });
                           
                          

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

                          Danke,
                          Jens

                          GlasfaserG 1 Reply Last reply
                          0
                          • DocdanD Offline
                            DocdanD Offline
                            Docdan
                            wrote on last edited by
                            #136

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

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

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

                            1 Reply Last reply
                            0
                            • DocdanD Docdan

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

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

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

                              Hier der code den ich benutze:

                              const url = 'http://www.solarprognose.de/web/solarprediction/api/v1?_format=json&access-token=78f1........ce0f&item=inverter&id=43..&type=hourly';
                              const path = '0_userdata.0.Solar.';
                              const idLeistung = path + 'Leistung.';
                              const idEnergie  = path + 'Energie.';
                               
                              schedule('16 4-22 * * *', function() { 
                                  request(url, function (error, response, result) {
                                      if(error) log(error, 'error');
                                      else {
                                          let obj = JSON.parse(result);
                                          if(obj.status) log('Fehler: ' + obj.status, 'warn');
                                          else {
                                              let data = obj.data;
                                              for(let entry in data) {
                                                  let time = formatDate(parseInt(entry), 'MM-DD.hh:mm');
                                                  if(existsState(idLeistung + time)) setState(idLeistung + time, data[entry][0], true);
                                                  else createState(idLeistung + time, data[entry][0], {
                                                      type: 'number', 
                                                      role: 'value', 
                                                      name: 'Solarleistung ' + formatDate(parseInt(entry), 'DD.MM. hh:mm'),
                                                      read: true,
                                                      write: false,
                                                      unit: 'kW'
                                                  });
                                                  if(existsState(idEnergie + time)) setState(idEnergie + time, data[entry][1], true);
                                                  else createState(idEnergie + time, data[entry][1], {
                                                      type: 'number', 
                                                      role: 'value', 
                                                      name: 'Solarenergie ' + formatDate(parseInt(entry), 'DD.MM. hh:mm'),
                                                      read: true,
                                                      write: false,
                                                      unit: 'kWh'
                                                  });
                                              }
                                          }
                                      }
                                  });
                              });
                               
                              

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

                              Danke,
                              Jens

                              GlasfaserG Offline
                              GlasfaserG Offline
                              Glasfaser
                              wrote on last edited by Glasfaser
                              #137

                              @docdan sagte in Solarprognose:

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

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

                              EDIT :

                              Nutze dieses nicht ....

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

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

                              DocdanD 1 Reply Last reply
                              0
                              • GlasfaserG Glasfaser

                                @docdan sagte in Solarprognose:

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

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

                                EDIT :

                                Nutze dieses nicht ....

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

                                DocdanD Offline
                                DocdanD Offline
                                Docdan
                                wrote on last edited by
                                #138

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

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

                                1 Reply Last reply
                                0
                                • DocdanD Offline
                                  DocdanD Offline
                                  Docdan
                                  wrote on last edited by Docdan
                                  #139

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

                                  Meister MopperM 1 Reply Last reply
                                  0
                                  • DocdanD Docdan

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

                                    Meister MopperM Online
                                    Meister MopperM Online
                                    Meister Mopper
                                    wrote on last edited by Meister Mopper
                                    #140

                                    @docdan sagte in Solarprognose:

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

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

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

                                    Proxmox und HA

                                    DocdanD 1 Reply Last reply
                                    0
                                    • Meister MopperM Meister Mopper

                                      @docdan sagte in Solarprognose:

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

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

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

                                      DocdanD Offline
                                      DocdanD Offline
                                      Docdan
                                      wrote on last edited by
                                      #141

                                      @meister-mopper

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

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

                                      Meister MopperM 1 Reply Last reply
                                      0
                                      • DocdanD Docdan

                                        @meister-mopper

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

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

                                        Meister MopperM Online
                                        Meister MopperM Online
                                        Meister Mopper
                                        wrote on last edited by
                                        #142

                                        @docdan sagte in Solarprognose:

                                        Habe das genauso jetzt eingebaut

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

                                        Proxmox und HA

                                        DocdanD 1 Reply Last reply
                                        0
                                        • Meister MopperM Meister Mopper

                                          @docdan sagte in Solarprognose:

                                          Habe das genauso jetzt eingebaut

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

                                          DocdanD Offline
                                          DocdanD Offline
                                          Docdan
                                          wrote on last edited by Docdan
                                          #143

                                          @meister-mopper

                                          So! Bisher läuft es!

                                          schedule('7 4-22 * * *', function() { 
                                              sleep(39000)
                                              request(url, function (error, response, result)
                                          
                                          DocdanD arteckA 2 Replies Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

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

                                          722

                                          Online

                                          32.6k

                                          Users

                                          82.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe