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

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

Community Forum

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

NEWS

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

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

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

Solarprognose

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

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

    1 Antwort Letzte Antwort
    0
    • GarganoG Offline
      GarganoG Offline
      Gargano
      schrieb am zuletzt editiert von
      #99

      @palm_maniac sagte in Solarprognose:

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

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

      Palm_ManiacP 1 Antwort Letzte Antwort
      0
      • GarganoG Gargano

        @palm_maniac sagte in Solarprognose:

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

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

        Palm_ManiacP Offline
        Palm_ManiacP Offline
        Palm_Maniac
        schrieb am zuletzt editiert von
        #100

        @gargano

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

        GarganoG 1 Antwort Letzte Antwort
        0
        • Palm_ManiacP Palm_Maniac

          @gargano

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

          GarganoG Offline
          GarganoG Offline
          Gargano
          schrieb am zuletzt editiert von
          #101

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

          Palm_ManiacP 1 Antwort Letzte Antwort
          0
          • GarganoG Gargano

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

            Palm_ManiacP Offline
            Palm_ManiacP Offline
            Palm_Maniac
            schrieb am zuletzt editiert von
            #102

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

            GarganoG 1 Antwort Letzte Antwort
            0
            • Palm_ManiacP Palm_Maniac

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

              GarganoG Offline
              GarganoG Offline
              Gargano
              schrieb am zuletzt editiert von Gargano
              #103

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

              Palm_ManiacP 1 Antwort Letzte Antwort
              0
              • GarganoG Gargano

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

                Palm_ManiacP Offline
                Palm_ManiacP Offline
                Palm_Maniac
                schrieb am zuletzt editiert von
                #104

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

                1 Antwort Letzte Antwort
                0
                • paul53P paul53

                  @babl sagte in Solarprognose:

                  schaut doch gut aus.

                  Dann hier ein komplettes Script, das jede Stunde von 4:16 Uhr bis 22:16 Uhr die Daten holt:

                  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'
                                      });
                                  }
                              }
                          }
                      });
                  });
                  
                  B Offline
                  B Offline
                  babl
                  schrieb am zuletzt editiert von
                  #105

                  @paul53 sagte in Solarprognose:

                  @babl sagte in Solarprognose:

                  schaut doch gut aus.

                  Dann hier ein komplettes Script, das jede Stunde von 4:16 Uhr bis 22:16 Uhr die Daten holt:

                  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'
                                      });
                                  }
                              }
                          }
                      });
                  });
                  

                  @paul53 könntest du mir vielleicht behilflich sein, da bei diesem Script nach dem update auf die neusten versionen genau der fehler kommt.

                  Read-only state "0_userdata.0.Solar.Leistung.morgen_21:00" has been written without ack-flag with value "0"
                  

                  Oder wie muß ich hier das script abändern damit die einträge im log weg sind.

                  Ansonsten läuft das Script hervorragend. Danke dir.

                  paul53P 1 Antwort Letzte Antwort
                  0
                  • B babl

                    @paul53 sagte in Solarprognose:

                    @babl sagte in Solarprognose:

                    schaut doch gut aus.

                    Dann hier ein komplettes Script, das jede Stunde von 4:16 Uhr bis 22:16 Uhr die Daten holt:

                    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'
                                        });
                                    }
                                }
                            }
                        });
                    });
                    

                    @paul53 könntest du mir vielleicht behilflich sein, da bei diesem Script nach dem update auf die neusten versionen genau der fehler kommt.

                    Read-only state "0_userdata.0.Solar.Leistung.morgen_21:00" has been written without ack-flag with value "0"
                    

                    Oder wie muß ich hier das script abändern damit die einträge im log weg sind.

                    Ansonsten läuft das Script hervorragend. Danke dir.

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

                    @babl sagte: der fehler kommt.

                    Der Fehler dürfte nicht kommen, da der Datenpunkt mit ack = true geschrieben wird (Zeile 16).

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

                    B 1 Antwort Letzte Antwort
                    0
                    • paul53P paul53

                      @babl sagte: der fehler kommt.

                      Der Fehler dürfte nicht kommen, da der Datenpunkt mit ack = true geschrieben wird (Zeile 16).

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

                      @paul53 leider kommt der fehler aber.

                      	Read-only state "0_userdata.0.Solar.Energie.morgen_21:00" has been written without ack-flag with value "42.403"
                      

                      zu jeder stunde habe ich hier ca. 50 warnmeldungen, die alle gleich lauten bis auf die Uhrzeit

                      paul53P HomoranH 2 Antworten Letzte Antwort
                      0
                      • B babl

                        @paul53 leider kommt der fehler aber.

                        	Read-only state "0_userdata.0.Solar.Energie.morgen_21:00" has been written without ack-flag with value "42.403"
                        

                        zu jeder stunde habe ich hier ca. 50 warnmeldungen, die alle gleich lauten bis auf die Uhrzeit

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

                        @babl sagte: zu jeder stunde habe ich hier ca. 50 warnmeldungen, die alle gleich lauten bis auf die Uhrzeit

                        Dann müssen die Fehler durch createState() erzeugt werden. Ich habe aber keine Ahnung, wie man createState() beibringt, den Initialwert mit ack = true zu schreiben.

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

                        1 Antwort Letzte Antwort
                        0
                        • B babl

                          @paul53 leider kommt der fehler aber.

                          	Read-only state "0_userdata.0.Solar.Energie.morgen_21:00" has been written without ack-flag with value "42.403"
                          

                          zu jeder stunde habe ich hier ca. 50 warnmeldungen, die alle gleich lauten bis auf die Uhrzeit

                          HomoranH Nicht stören
                          HomoranH Nicht stören
                          Homoran
                          Global Moderator Administrators
                          schrieb am zuletzt editiert von
                          #109

                          @paul53

                          Ist die Ursache nicht eher der

                          @babl sagte in Solarprognose:

                          Read-only state

                          kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                          Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                          der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                          paul53P 1 Antwort Letzte Antwort
                          0
                          • HomoranH Homoran

                            @paul53

                            Ist die Ursache nicht eher der

                            @babl sagte in Solarprognose:

                            Read-only state

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

                            @homoran sagte: Ist die Ursache nicht eher der Read-only state

                            Ja, das könnte man ändern, widerspricht aber der Logik, dass es reine Anzeigewerte sind.

                            @babl Ändere mal Zeilen 22 und 31 in

                                                    write: true,
                            

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

                            B 3 Antworten Letzte Antwort
                            0
                            • paul53P paul53

                              @homoran sagte: Ist die Ursache nicht eher der Read-only state

                              Ja, das könnte man ändern, widerspricht aber der Logik, dass es reine Anzeigewerte sind.

                              @babl Ändere mal Zeilen 22 und 31 in

                                                      write: true,
                              
                              B Offline
                              B Offline
                              babl
                              schrieb am zuletzt editiert von
                              #111

                              @paul53 ok wurde geändert, warten wir mal den nächsten durchlauf ab.

                              1 Antwort Letzte Antwort
                              0
                              • paul53P paul53

                                @homoran sagte: Ist die Ursache nicht eher der Read-only state

                                Ja, das könnte man ändern, widerspricht aber der Logik, dass es reine Anzeigewerte sind.

                                @babl Ändere mal Zeilen 22 und 31 in

                                                        write: true,
                                
                                B Offline
                                B Offline
                                babl
                                schrieb am zuletzt editiert von babl
                                #112

                                @paul53 nein das war es nicht

                                	Read-only state "0_userdata.0.Solar.Energie.morgen_21:00" has been written without ack-flag with value "42.403"
                                javascript.0
                                	2021-08-08 14:07:00.323	warn	Read-only state "0_userdata.0.Solar.Leistung.morgen_21:00" has been written without ack-flag with value "0"
                                javascript.0
                                	2021-08-08 14:07:00.323	warn	Read-only state "0_userdata.0.Solar.Energie.morgen_20:00" has been written without ack-flag with value "42.403"
                                javascript.0
                                	2021-08-08 14:07:00.322	warn	Read-only state "0_userdata.0.Solar.Leistung.morgen_20:00" has been written without ack-flag with value "0.114"
                                javascript.0
                                	2021-08-08 14:07:00.321	warn	Read-only state "0_userdata.0.Solar.Energie.morgen_19:00" has been written without ack-flag with value "42.289"
                                javascript.0
                                	2021-08-08 14:07:00.320	warn	Read-only state "0_userdata.0.Solar.Leistung.morgen_19:00" has been written without ack-flag with value "0.908"
                                

                                Soll ich mal alle Objekte löschen?

                                Das Write ändere ich wieder zu false

                                paul53P 1 Antwort Letzte Antwort
                                0
                                • B babl

                                  @paul53 nein das war es nicht

                                  	Read-only state "0_userdata.0.Solar.Energie.morgen_21:00" has been written without ack-flag with value "42.403"
                                  javascript.0
                                  	2021-08-08 14:07:00.323	warn	Read-only state "0_userdata.0.Solar.Leistung.morgen_21:00" has been written without ack-flag with value "0"
                                  javascript.0
                                  	2021-08-08 14:07:00.323	warn	Read-only state "0_userdata.0.Solar.Energie.morgen_20:00" has been written without ack-flag with value "42.403"
                                  javascript.0
                                  	2021-08-08 14:07:00.322	warn	Read-only state "0_userdata.0.Solar.Leistung.morgen_20:00" has been written without ack-flag with value "0.114"
                                  javascript.0
                                  	2021-08-08 14:07:00.321	warn	Read-only state "0_userdata.0.Solar.Energie.morgen_19:00" has been written without ack-flag with value "42.289"
                                  javascript.0
                                  	2021-08-08 14:07:00.320	warn	Read-only state "0_userdata.0.Solar.Leistung.morgen_19:00" has been written without ack-flag with value "0.908"
                                  

                                  Soll ich mal alle Objekte löschen?

                                  Das Write ändere ich wieder zu false

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

                                  @babl sagte: nein das war es nicht

                                  Das kommt nicht von dem Skript, das Du gepostet hast. Dieses Skript erzeugt Datenpunkte mit der ID "0_userdata.0.Solar.Leistung.08-09.21:00" und nicht mit der ID "0_userdata.0.Solar.Leistung.morgen_21:00".

                                  Poste bitte das richtige Skript.

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

                                  1 Antwort Letzte Antwort
                                  0
                                  • paul53P paul53

                                    @homoran sagte: Ist die Ursache nicht eher der Read-only state

                                    Ja, das könnte man ändern, widerspricht aber der Logik, dass es reine Anzeigewerte sind.

                                    @babl Ändere mal Zeilen 22 und 31 in

                                                            write: true,
                                    
                                    B Offline
                                    B Offline
                                    babl
                                    schrieb am zuletzt editiert von
                                    #114

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

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

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

                                    Ich danke euch beiden.

                                    paul53P 1 Antwort Letzte Antwort
                                    0
                                    • B babl

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

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

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

                                      Ich danke euch beiden.

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

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

                                      @babl sagte in Solarprognose:

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

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

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

                                      B 1 Antwort Letzte Antwort
                                      0
                                      • paul53P paul53

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

                                        @babl sagte in Solarprognose:

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

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

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

                                        @paul53

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

                                        Das hier ist das Script

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

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

                                          @paul53

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

                                          Das hier ist das Script

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

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

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

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

                                          und

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

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

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


                                          Support us

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

                                          862

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

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

                                          • Du hast noch kein Konto? Registrieren

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