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
    3.1k

  • 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.8k 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.
  • Palm_ManiacP Palm_Maniac

    @streit187

    Nein, das ist ja meine Rede, ich brauche die alten Daten nicht, aber das Skript wird sie erzeugen, deshalb meine Frage wo man das Skript abändern kann/muß, damit nur diese 2 Datenpunkte angelegt und zukünftig aktualisiert werden.

    S Offline
    S Offline
    Streit187
    wrote on last edited by
    #94

    @palm_maniac Nein, das tut das Skript nicht. Morgen ist Morgen heute und übermorgen morgen. Es bleibt bei diesen beiden Ordnern mit den dazugehörigen Datenpunkten und die Werte werden genau so aktualisiert wie du es brauchst.

    Palm_ManiacP 1 Reply Last reply
    0
    • S Streit187

      @palm_maniac Nein, das tut das Skript nicht. Morgen ist Morgen heute und übermorgen morgen. Es bleibt bei diesen beiden Ordnern mit den dazugehörigen Datenpunkten und die Werte werden genau so aktualisiert wie du es brauchst.

      Palm_ManiacP Offline
      Palm_ManiacP Offline
      Palm_Maniac
      wrote on last edited by
      #95

      @streit187

      Schau mal:

      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'
      

      Hier wird doch das Datum geparst und weiter unten in den Namen/Pfad eingebaut, was doch dazu führt, dass immer neue Ordner entstehen nach dem Schema 03-10, 03-11, 03-12 usw. Die Begriffe "Heute" und "Morgen" tauchen in diesem Skript nicht auf, so würde es mir aber reichen.

      Oder verstehe ich das Skript da falsch?

      S 1 Reply Last reply
      0
      • Palm_ManiacP Palm_Maniac

        @streit187

        Schau mal:

        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'
        

        Hier wird doch das Datum geparst und weiter unten in den Namen/Pfad eingebaut, was doch dazu führt, dass immer neue Ordner entstehen nach dem Schema 03-10, 03-11, 03-12 usw. Die Begriffe "Heute" und "Morgen" tauchen in diesem Skript nicht auf, so würde es mir aber reichen.

        Oder verstehe ich das Skript da falsch?

        S Offline
        S Offline
        Streit187
        wrote on last edited by
        #96

        @palm_maniac Wo kommt denn dieser Code her? Der ist nicht Bestandteil von deinem Ursprünglichen Skript in https://forum.iobroker.net/topic/37314/solarprognose/73.

        Palm_ManiacP 1 Reply Last reply
        0
        • S Streit187

          @palm_maniac Wo kommt denn dieser Code her? Der ist nicht Bestandteil von deinem Ursprünglichen Skript in https://forum.iobroker.net/topic/37314/solarprognose/73.

          Palm_ManiacP Offline
          Palm_ManiacP Offline
          Palm_Maniac
          wrote on last edited by
          #97

          @streit187

          Doch, hab gerade nochmal nachgeschaut.

          1 Reply Last reply
          0
          • Palm_ManiacP Offline
            Palm_ManiacP Offline
            Palm_Maniac
            wrote on last edited by
            #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 Reply Last reply
            0
            • GarganoG Offline
              GarganoG Offline
              Gargano
              wrote on last edited by
              #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 Reply Last reply
              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
                wrote on last edited by
                #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 Reply Last reply
                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
                  wrote on last edited by
                  #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 Reply Last reply
                  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
                    wrote on last edited by
                    #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 Reply Last reply
                    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
                      wrote on last edited by Gargano
                      #103

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

                      Palm_ManiacP 1 Reply Last reply
                      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
                        wrote on last edited by
                        #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 Reply Last reply
                        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 Online
                          B Online
                          babl
                          wrote on last edited by
                          #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 Reply Last reply
                          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
                            wrote on last edited by
                            #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 Reply Last reply
                            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 Online
                              B Online
                              babl
                              wrote on last edited by
                              #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 Replies Last reply
                              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
                                wrote on last edited by
                                #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 Reply Last reply
                                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 Do not disturb
                                  HomoranH Do not disturb
                                  Homoran
                                  Global Moderator Administrators
                                  wrote on last edited by
                                  #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 Reply Last reply
                                  0
                                  • HomoranH Homoran

                                    @paul53

                                    Ist die Ursache nicht eher der

                                    @babl sagte in Solarprognose:

                                    Read-only state

                                    paul53P Offline
                                    paul53P Offline
                                    paul53
                                    wrote on last edited by 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 Replies Last reply
                                    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 Online
                                      B Online
                                      babl
                                      wrote on last edited by
                                      #111

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

                                      1 Reply Last reply
                                      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 Online
                                        B Online
                                        babl
                                        wrote on last edited by 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 Reply Last reply
                                        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
                                          wrote on last edited by 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 Reply 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

                                          772

                                          Online

                                          32.7k

                                          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