Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. [Vorlage] Stromverbrauch protokollieren - (etwas optimiert)

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [Vorlage] Stromverbrauch protokollieren - (etwas optimiert)

    This topic has been deleted. Only users with topic management privileges can see it.
    • cvidal
      cvidal Forum Testing last edited by

      @dering:

      Mach mal Screenshots von den Objekten in ioBroker. Am besten die ganze Baumstruktur aufklappen, damit man sieht, welchen Wert man mitloggen muss. `

      Danke für die Rückmeldung,

      ich hoffe damit kannst du Arbeiten 🙂

      TP-Link HS110:
      2113_hs110.png

      Sonoff POW:
      2113_hs110.png
      Gruß Christian

      1 Reply Last reply Reply Quote 0
      • D
        dering last edited by

        @cvidal:

        @dering:

        Mach mal Screenshots von den Objekten in ioBroker. Am besten die ganze Baumstruktur aufklappen, damit man sieht, welchen Wert man mitloggen muss. `

        Danke für die Rückmeldung,

        ich hoffe damit kannst du Arbeiten 🙂

        TP-Link HS110:

        HS110.PNG

        Sonoff POW:

        HS110.PNG

        Gruß Christian `

        Hi Christian,

        das sind zweimal die gleichen Bilder oder?

        1 Reply Last reply Reply Quote 0
        • N
          Nepomukl last edited by

          Hallo Gemeinde,

          kann es sein das da irgendwo ein Fehler im Script ist.

          2 mal meckert er mich an mit 'var message = geraetename + ….' das message schon definiert ist.

          das ist aber nicht das schlimmste.

          Ab Zeile 434 sagt er Zu viele Fehler, 64 % gescannt.

          Dadurch läuft das Script nicht.

          Hab es schon mehrfach neu geladen. Wo kann der Fehler liegen?

          Gruß Andreas

          1 Reply Last reply Reply Quote 0
          • D
            dering last edited by

            @Nepomukl:

            Hallo Gemeinde,

            kann es sein das da irgendwo ein Fehler im Script ist.

            2 mal meckert er mich an mit 'var message = geraetename + ….' das message schon definiert ist.

            das ist aber nicht das schlimmste.

            Ab Zeile 434 sagt er Zu viele Fehler, 64 % gescannt.

            Dadurch läuft das Script nicht.

            Hab es schon mehrfach neu geladen. Wo kann der Fehler liegen?

            Gruß Andreas `

            Hi Andreas,

            das ist nur eine Warnung, daran sollte es nicht liegen, warum es nicht läuft.

            Aktiviere mal das logging und schau was dort angezeigt wird. Du kannst auch gerne den Inhalt posten und ich schau nach:

            var logging = true;
            

            PS:

            In der nächsten Version ändere ich es ab, dass keine Warnung mehr kommt 🙂

            1 Reply Last reply Reply Quote 0
            • N
              Nepomukl last edited by

              Das mit den Warnungen von message hab ich auch so gesehen.

              Also logging war an und es sagt nix. Ganz normal nur die Startausgabe, wenn ich das Script Stoppe

              wird es mir auch mitgeteilt, dazwischen nix.

              An Objekten legt er auch unter Strom nur den Preis an. Weiter kommt nix.

              An dieser Stelle sagt er dann To many errors (64 % scanned)
              847_to_many_errors.jpg

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

                Zum Thema "too many errors" –> viewtopic.php?f=8&t=7139&hilit=too+many+errors

                1 Reply Last reply Reply Quote 0
                • cvidal
                  cvidal Forum Testing last edited by

                  @dering:

                  Hi Christian,

                  das sind zweimal die gleichen Bilder oder? `

                  Ja, sorry.

                  Hier nochmal die Sonoff POW Objekte:
                  2113_sonoffpow.png
                  Gruß Christian

                  1 Reply Last reply Reply Quote 0
                  • N
                    Nepomukl last edited by

                    ups, das ist im falschen Fred gelandet.

                    Jo mit der Angabe tuts das Script.

                    Nun etwas anderes. Das bezieht sich ja alles auf HM Produkte.

                    Das brauch ich in diesem Script nicht.

                    Kann man nicht am Anfang des Scriptes einen Datenpunkt angeben der Ausgewertet werden soll?

                    Einen Zählerstand, oder ein HM Fremdes Gerät.

                    Das wäre mir lieber 😄

                    Gruß Andreas

                    1 Reply Last reply Reply Quote 0
                    • D
                      dering last edited by

                      Version 1.1.0 ist nun online:

                      https://github.com/hdering/homematic_st … okollieren

                      1.1.0 (2018-03-12)

                      • (hdering) Arbeitspreis + Grundpreis werden nicht mehr über das Skript gesetzt.

                      • (hdering) Neuer Arbeitspreis + Grundpreis können innerhalb des Jahres angegeben werden.

                      • (hdering) Geräte können ihren eigenen Strompreis haben.

                      • (hdering) Geräte mit eigenem Strompreis haben ebenfalls die Funktion Arbeitspreis + Grundpreis innerhalb des Jahres zu ändern.

                      • (hdering) Eigene Datenpunkte angeben

                      • (hdering) Fehler in Funktion entferneDatenpunkt behoben

                      1 Reply Last reply Reply Quote 0
                      • D
                        dering last edited by

                        @cvidal:

                        @dering:

                        Mach mal Screenshots von den Objekten in ioBroker. Am besten die ganze Baumstruktur aufklappen, damit man sieht, welchen Wert man mitloggen muss. `

                        Danke für die Rückmeldung,

                        ich hoffe damit kannst du Arbeiten 🙂

                        TP-Link HS110:

                        HS110.PNG

                        Sonoff POW:

                        HS110.PNG

                        Gruß Christian `

                        Version 1.1.0 ist nun online:

                        https://github.com/hdering/homematic_st … okollieren

                        1.1.0 (2018-03-12)

                        • (hdering) Arbeitspreis + Grundpreis werden nicht mehr über das Skript gesetzt.

                        • (hdering) Neuer Arbeitspreis + Grundpreis können innerhalb des Jahres angegeben werden.

                        • (hdering) Geräte können ihren eigenen Strompreis haben.

                        • (hdering) Geräte mit eigenem Strompreis haben ebenfalls die Funktion Arbeitspreis + Grundpreis innerhalb des Jahres zu ändern.

                        • (hdering) Eigene Datenpunkte angeben

                        • (hdering) Fehler in Funktion entferneDatenpunkt behoben

                        1 Reply Last reply Reply Quote 0
                        • D
                          dering last edited by

                          @Nepomukl:

                          ups, das ist im falschen Fred gelandet.

                          Jo mit der Angabe tuts das Script.

                          Nun etwas anderes. Das bezieht sich ja alles auf HM Produkte.

                          Das brauch ich in diesem Script nicht.

                          Kann man nicht am Anfang des Scriptes einen Datenpunkt angeben der Ausgewertet werden soll?

                          Einen Zählerstand, oder ein HM Fremdes Gerät.

                          Das wäre mir lieber 😄

                          Gruß Andreas `

                          Version 1.1.0 ist nun online:

                          https://github.com/hdering/homematic_st … okollieren

                          1.1.0 (2018-03-12)

                          • (hdering) Arbeitspreis + Grundpreis werden nicht mehr über das Skript gesetzt.

                          • (hdering) Neuer Arbeitspreis + Grundpreis können innerhalb des Jahres angegeben werden.

                          • (hdering) Geräte können ihren eigenen Strompreis haben.

                          • (hdering) Geräte mit eigenem Strompreis haben ebenfalls die Funktion Arbeitspreis + Grundpreis innerhalb des Jahres zu ändern.

                          • (hdering) Eigene Datenpunkte angeben

                          • (hdering) Fehler in Funktion entferneDatenpunkt behoben

                          1 Reply Last reply Reply Quote 0
                          • P
                            ple last edited by

                            Yeah, das muss ich heute Abend mal testen;-)

                            Besten Dank für deine Bemühungen;-)

                            Gruß

                            1 Reply Last reply Reply Quote 0
                            • N
                              Nepomukl last edited by

                              Top 😄

                              habs gleich mal eingebaut. Jetzt gehts ans Testen.

                              Bist ja wirklich fix 😉

                              Besten Dank !!!

                              Gruß Andreas

                              1 Reply Last reply Reply Quote 0
                              • M
                                Mac last edited by

                                ****Hallo,

                                danke erst einmal dass Du Deine Arbeit teilst und hilfst.

                                Meine Datenpunkte bekomme ich aus einem Loxone Mini Server und KNX Datenpunkten. Ich habe ein Stromzählerstand in Dein Script eingesetzt, aber offensichtlich habe ich die notwendigen Einstellungen nicht verstanden. Würdest Du es mir bitte noch mal erläutern hier meine Ansatz:****

                                // debug logging

                                var logging = true;

                                // Aktivieren der History Instanz

                                var enable_history = true;

                                // history Instanz

                                var instance_history = 'history.0';

                                // Geräte können unterschiedliche Preise haben

                                var enable_unterschiedlichePreise = true;

                                // Speichern der Werte in zusätzlichen Objekten.

                                // Wenn 0, dann deaktiviert

                                var Tag_Anzahl_Werte_in_der_Vergangenheit = 7;

                                var Woche_Anzahl_Werte_in_der_Vergangenheit = 4;

                                var Monat_Anzahl_Werte_in_der_Vergangenheit = 12;

                                var Quartal_Anzahl_Werte_in_der_Vergangenheit = 4;

                                var Jahr_Anzahl_Werte_in_der_Vergangenheit = 2;

                                var instance = '0';

                                var instanz = 'javascript.' + instance + '.';

                                // Pfad innerhalb der Instanz

                                var pfad = 'Strom.';

                                // Diese Teile werden aus den Gerätenamen entfernt

                                var blacklist = [':1', ':2', ':3', ':4', ':5', ':6', ':7', ':8'];

                                var AnzahlKommastellenKosten = 2;

                                var AnzahlKommastellenVerbrauch = 3;

                                var AnzahlKommastellenZaehlerstand = 3;

                                var eigeneDatenpunkte = [

                                // Beispiel:

                                // ['Datenpunkt', 'Aliasname'],

                                [ 'loxone.0.114bea65-0309-2a96-ffff403fb0c34b9e.value', 'Allgemeinstrom' ],

                                // [ 'javascript.1.MeinePower', 'MeinSonoff' ],

                                // [ 'javascript.1.MeinePower2', 'Sonoff.MeinZweiterSonoff' ],

                                ];

                                B: Kann ich auch einen Gasverbrauch damit loggen?

                                Mit besten Grüßen

                                1 Reply Last reply Reply Quote 0
                                • P
                                  ple last edited by

                                  Sieht soweit alles gut aus, könnte sein, dass er mit dem "-" nicht klar kommt.

                                  Wie hast du den Datenpunkt eingetragen? Über den Kopierbutton unter Objekte bei ID? Vielleicht ist auch ein Fehler im Namen.

                                  Für Gasverbrauch wäre das auch was, jedoch ist die Angabe in kWh.

                                  Was ich mir wünschen würde, wäre für jeden Datenpunkt eine Einheit die man selbst bestimmt. Zusätzlich wäre noch ein Teiler erforderlich, da einige Sensoren nicht nur Wh ausgeben sonder auch kWh.

                                  Dann wäre das Script perfekt für alle Energietypen.

                                  Was bei mir noch auffällt. Gestern Abend habe ich das Script aktiviert, danach wurde um 12 nicht genullt, sondern weitergezählt.

                                  Muss da noch was eingestellt werden??

                                  Großen Dank für deine Bemühungen !!!

                                  1 Reply Last reply Reply Quote 0
                                  • D
                                    dering last edited by

                                    @Mac:

                                    ****Hallo,

                                    danke erst einmal dass Du Deine Arbeit teilst und hilfst.

                                    Meine Datenpunkte bekomme ich aus einem Loxone Mini Server und KNX Datenpunkten. Ich habe ein Stromzählerstand in Dein Script eingesetzt, aber offensichtlich habe ich die notwendigen Einstellungen nicht verstanden. Würdest Du es mir bitte noch mal erläutern hier meine Ansatz:****

                                    // debug logging

                                    var logging = true;

                                    // Aktivieren der History Instanz

                                    var enable_history = true;

                                    // history Instanz

                                    var instance_history = 'history.0';

                                    // Geräte können unterschiedliche Preise haben

                                    var enable_unterschiedlichePreise = true;

                                    // Speichern der Werte in zusätzlichen Objekten.

                                    // Wenn 0, dann deaktiviert

                                    var Tag_Anzahl_Werte_in_der_Vergangenheit = 7;

                                    var Woche_Anzahl_Werte_in_der_Vergangenheit = 4;

                                    var Monat_Anzahl_Werte_in_der_Vergangenheit = 12;

                                    var Quartal_Anzahl_Werte_in_der_Vergangenheit = 4;

                                    var Jahr_Anzahl_Werte_in_der_Vergangenheit = 2;

                                    var instance = '0';

                                    var instanz = 'javascript.' + instance + '.';

                                    // Pfad innerhalb der Instanz

                                    var pfad = 'Strom.';

                                    // Diese Teile werden aus den Gerätenamen entfernt

                                    var blacklist = [':1', ':2', ':3', ':4', ':5', ':6', ':7', ':8'];

                                    var AnzahlKommastellenKosten = 2;

                                    var AnzahlKommastellenVerbrauch = 3;

                                    var AnzahlKommastellenZaehlerstand = 3;

                                    var eigeneDatenpunkte = [

                                    // Beispiel:

                                    // ['Datenpunkt', 'Aliasname'],

                                    [ 'loxone.0.114bea65-0309-2a96-ffff403fb0c34b9e.value', 'Allgemeinstrom' ],

                                    // [ 'javascript.1.MeinePower', 'MeinSonoff' ],

                                    // [ 'javascript.1.MeinePower2', 'Sonoff.MeinZweiterSonoff' ],

                                    ];

                                    B: Kann ich auch einen Gasverbrauch damit loggen?

                                    Mit besten Grüßen `

                                    hi Mac,

                                    ich habe mal den Datenpunkt "loxone.0.114bea65-0309-2a96-ffff403fb0c34b9e.value" in meinem Testskript eingebaut. Er meckert mal nicht.

                                    Logging ist aktiviert -> gut.

                                    Was sagt den die Ausgabe? Irgendeine Ausgabe müsste ja kommen.

                                    Da du den Alias "Allgemeinstrom" angegeben hast, sollte in deiner javascript Instanz in .Strom das Verzeichnis .Allgemeinstrom erstellt werden. Kannst du das bestätigen?

                                    Zum Gasverbrauch schreib ich nochmal.

                                    1 Reply Last reply Reply Quote 0
                                    • D
                                      dering last edited by

                                      @ple:

                                      Für Gasverbrauch wäre das auch was, jedoch ist die Angabe in kWh.

                                      Was ich mir wünschen würde, wäre für jeden Datenpunkt eine Einheit die man selbst bestimmt. Zusätzlich wäre noch ein Teiler erforderlich, da einige Sensoren nicht nur Wh ausgeben sonder auch kWh.

                                      Dann wäre das Script perfekt für alle Energietypen. `

                                      für die eigenenDatenpunkte ergänze ich noch um ein Feld für Gasverbrauch.

                                      @ple:

                                      Was bei mir noch auffällt. Gestern Abend habe ich das Script aktiviert, danach wurde um 12 nicht genullt, sondern weitergezählt.

                                      Muss da noch was eingestellt werden?? `

                                      Existieren bei den Objekten beim jeweiligen Stromzähler ein Ordner config? und dort Tag, Woche, Monat…usw?

                                      1 Reply Last reply Reply Quote 0
                                      • M
                                        Mac last edited by

                                        Das ist ja toll, eine so schnelle Antwort, danke.

                                        Ja es sind Ordner und Datensätze erzeugt worden, ich kann dort aber keine Werte eintragen:

                                        4489_bildschirmfoto_2018-03-13_um_21.50.57.png

                                        1 Reply Last reply Reply Quote 0
                                        • D
                                          dering last edited by

                                          @Mac:

                                          Das ist ja toll, eine so schnelle Antwort, danke.

                                          Ja es sind Ordner und Datensätze erzeugt worden, ich kann dort aber keine Werte eintragen:

                                          Bildschirmfoto 2018-03-13 um 21.50.57.png `

                                          Das Skript sollte eigentlich melden, dass der Arbeitspreis auf 0 steht und somit keine Berechnungen durchgeführt werden können und somit auch abbricht.

                                          Siehst du diese Meldung?

                                          Kannst du den Arbeitspreis nicht editieren? Rechts auf die 0 klicken und dann deinen aktuellen Arbeitspreis eingeben, z.B. 0.26

                                          1 Reply Last reply Reply Quote 0
                                          • M
                                            Mac last edited by

                                            Hallo, es war meine Dusseligkeit ein Komma statt des Punktes zu verwenden, jetzt klappt das Einsetzen der beiden Preise.

                                            4489_bildschirmfoto_2018-03-14_um_07.53.40.png

                                            Zu Deiner Frage, nein, es ist keine Meldung erschienen, wo hätte ich die denn sehen müssen?

                                            Wenn es verschiedene Punkte sind wie erkenne ich den deren Zuordnung? Ich habe jetzt zwei Punkte zusätzlich gesetzt, es erscheint aber noch kein weiterer Ordner?
                                            4489_bildschirmfoto_2018-03-14_um_08.02.40.png

                                            Erscheinen die Speicherwerte erst wenn ein Verbrauch stattfand?

                                            Wird auch der eigentliche Verbrauch in kWh gespeichert?

                                            Kann ich mehr als drei Punkte einsetzen?

                                            Wird man die Preise von der Vis aus editieren können?

                                            Danke Dir noch mal für die Hilfe.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            437
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            81
                                            455
                                            104140
                                            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