Navigation

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

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Solarprognose

    This topic has been deleted. Only users with topic management privileges can see it.
    • S
      Streit187 @Palm_Maniac last edited by

      @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_Maniac 1 Reply Last reply Reply Quote 0
      • Palm_Maniac
        Palm_Maniac @Streit187 last edited by

        @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 Reply Quote 0
        • S
          Streit187 @Palm_Maniac last edited by

          @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_Maniac 1 Reply Last reply Reply Quote 0
          • Palm_Maniac
            Palm_Maniac @Streit187 last edited by

            @streit187

            Doch, hab gerade nochmal nachgeschaut.

            1 Reply Last reply Reply Quote 0
            • Palm_Maniac
              Palm_Maniac last edited by

              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 Reply Quote 0
              • Gargano
                Gargano last edited by

                @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_Maniac 1 Reply Last reply Reply Quote 0
                • Palm_Maniac
                  Palm_Maniac @Gargano last edited by

                  @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.

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

                    @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_Maniac 1 Reply Last reply Reply Quote 0
                    • Palm_Maniac
                      Palm_Maniac @Gargano last edited by

                      @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.

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

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

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

                          @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 Reply Quote 0
                          • B
                            babl @paul53 last edited by

                            @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.

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

                              @babl sagte: der fehler kommt.

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

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

                                @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

                                paul53 Homoran 2 Replies Last reply Reply Quote 0
                                • paul53
                                  paul53 @babl last edited by

                                  @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.

                                  1 Reply Last reply Reply Quote 0
                                  • Homoran
                                    Homoran Global Moderator Administrators @babl last edited by

                                    @paul53

                                    Ist die Ursache nicht eher der

                                    @babl sagte in Solarprognose:

                                    Read-only state

                                    paul53 1 Reply Last reply Reply Quote 0
                                    • paul53
                                      paul53 @Homoran last edited by 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 3 Replies Last reply Reply Quote 0
                                      • B
                                        babl @paul53 last edited by

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

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

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

                                            @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.

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

                                            Support us

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

                                            837
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

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