Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. Gaszähler auswerten - Problem

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Gaszähler auswerten - Problem

    This topic has been deleted. Only users with topic management privileges can see it.
    • Asgothian
      Asgothian Developer @DasMoritz last edited by

      @dasmoritz sagte in Gaszähler auswerten - Problem:

      @asgothian

      Hi,

      bevor ich das tue...
      Ich bekomme beim Ausführen des Skriptes (wie oben) die folgende Fehlermeldung:

      09:16:44.821	error	javascript.0 (2028) script.js.Moritz_Script.Gaszähler.Gaszähler_Moritz: TypeError: Cannot read property '0' of undefined
      09:16:44.821	error	javascript.0 (2028) at Object.<anonymous> (script.js.Moritz_Script.Gaszähler.Gaszähler_Moritz:23:77)
      

      Das muss nach meinem Verständnis diesen Block betreffen:

        while (Gesamtzeit < 600) {
          Gesamtpulse = (typeof Gesamtpulse == 'number' ? Gesamtpulse : 0) + Liste[(Zaehler - 1)];
          Gesamtzeit = (typeof Gesamtzeit == 'number' ? Gesamtzeit : 0) + Zeitliste[(Zaehler - 1)];
          Zaehler = (typeof Zaehler == 'number' ? Zaehler : 0) + 1;
      

      als Blockly:
      dd17b46c-40e1-40a9-97a7-9819e8bac2fd-image.png

      Da hast du recht - da ist mir ein Fehler unterlaufen :

      dieses
      Screenshot 2021-11-11 at 09.30.45.png

      muss auf
      Screenshot 2021-11-11 at 09.33.10.png

      erweitert werden.

      A.

      D 1 Reply Last reply Reply Quote 0
      • D
        DasMoritz @Asgothian last edited by

        @asgothian

        ist angepasst:
        2e031d29-f7cc-45cb-833b-d5fc22c6c73b-image.png

        Es kommt jedoch weiterhin der gleiche Fehler.
        cf6abb8e-0f75-486f-9d8b-00b2701666a5-image.png

        Asgothian 1 Reply Last reply Reply Quote 0
        • T
          tomba0815 last edited by tomba0815

          Hallo,
          wenn das auch nicht zu dem konkreten Problem passt ...
          Ich hatte meinen Gaszähler auch bis vor einem Jahr mit einem Reed-Kontakt ausgelesen und ähnliche Probleme wie du.
          Bin dann umgestiegen auf das hier:
          https://forum.iobroker.net/topic/23577/wasserzähler-selfmade
          Funktioniert ohne größere Probleme, Hardwarekosten sind sehr gering.
          Evtl. wäre das ja auch etwas für dich ??

          Grüße
          Thomas

          D 1 Reply Last reply Reply Quote 0
          • D
            DasMoritz @tomba0815 last edited by

            @tomba0815 Hi,

            Danke, spannend.
            Ich möchte erstmal meinen Gasverbrauch digital auslesen können.
            Das ganze soll eigentlich als Vorbereitung für eine Wärmepumpe dienen um zu erfassen, wie hoch meine Heizlast im Winter ist.

            Die Heizung läuft momentan maximal auf 3kW (technisch limitiert), sodass die Daten mich vorrangig interessieren.

            Aber: Das ist schon super spannend.

            1 Reply Last reply Reply Quote 0
            • Asgothian
              Asgothian Developer @DasMoritz last edited by

              @dasmoritz

              Ich war noch nicht wach.. es fehlt noch eine Abfrage, dann muss es gehen. Wenn wir Teile der Liste leeren wollen müssen wir sicherstellen das wir auch genügend Einträge in der Liste haben.

              Screenshot 2021-11-11 at 10.51.51.png

              D 1 Reply Last reply Reply Quote 0
              • D
                DasMoritz @Asgothian last edited by

                @asgothian

                Hi,

                alles fein, ich bin unendlich dankbar für deine Hilfe.

                Ich habe das nun sehr weit unten im Skript eingebaut, in der Hoffnung es ist an der richtigen Stelle:
                fb35a8af-fd12-4743-bbc9-a47ad52e533c-image.png

                Weiterhin gleicher Fehler.

                Asgothian 1 Reply Last reply Reply Quote 0
                • Asgothian
                  Asgothian Developer @DasMoritz last edited by

                  @dasmoritz zeig nochmal das ganze Skript

                  A.

                  D 1 Reply Last reply Reply Quote 0
                  • D
                    DasMoritz @Asgothian last edited by

                    @asgothian

                    Da ist es 🙂

                    0038103f-35b0-4a6e-a408-b37ee29d9137-image.png

                    Asgothian paul53 2 Replies Last reply Reply Quote 0
                    • Asgothian
                      Asgothian Developer @DasMoritz last edited by Asgothian

                      @dasmoritz hmm.. bitte auch noch mal den generierten JS Code - da passt etwas nicht zusammen

                      A.

                      Nachtrag: Ich glaube ich hab den Fehler:
                      An stelle von
                      Screenshot 2021-11-11 at 11.19.50.png

                      müsstest Du den Baustein so einstellen, jeweils für beide listen.

                      Screenshot 2021-11-11 at 11.19.36.png

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

                        @dasmoritz
                        Wenn auf Wertänderung getriggert wird, muss man zur Berechnung der Leistung "letzte Änderung" und "vorherige letzte Änderung" verwenden.
                        Das Skript ist viel zu kompliziert, denn die Leistung berechnet man mit

                        Leistung = Faktor * (Wert - vorheriger Wert) / (letzte Änderung - vorherige letzte Änderung)
                        

                        , egal wie viele Impulse zwischen zwei Trigger-Ereignissen gezählt wurden.

                        1 Reply Last reply Reply Quote 0
                        • D
                          DasMoritz @Asgothian last edited by

                          @asgothian

                          Oh man, weiterhin der gleiche Fehler.
                          Hier noch einmal der aktuelle Blockly und der Code:

                          68213aaa-7eb9-40fc-91bb-07dcb728fee0-image.png

                          var Z_C3_A4hlerliste, Zeitliste, timeout, Gesamtzeit, Gesamtpulse, Zaehler, Liste;
                          
                          
                          Z_C3_A4hlerliste = [];
                          Zeitliste = [];
                          on({id: 'mqtt.0.SmartHome.Sensor.Haustechnikraum.Impulszaehler.Zaehler_0.Impulse', change: "ne"}, async function (obj) {
                            var value = obj.state.val;
                            var oldValue = obj.oldState.val;
                            (function () {if (timeout) {clearTimeout(timeout); timeout = null;}})();
                            timeout = setTimeout(async function () {
                              // BrennerAktiv
                              setState("javascript.0.Gaszaehler.BrennerAktiv"/*BrennerAktiv*/, false, true);
                              // Pulse pro Sekunde
                              setState("javascript.0.Gaszaehler.Impulse_Scriptneu"/*Impulse_Scriptneu*/, 0, true);
                            }, 180000);
                            setState("javascript.0.Gaszaehler.BrennerAktiv"/*BrennerAktiv*/, true, true);
                            Z_C3_A4hlerliste.unshift((obj.state ? obj.state.val : "") - (obj.oldState ? obj.oldState.val : ""));
                            Zeitliste.unshift(((obj.state ? obj.state.ts : "") - (obj.oldState ? obj.oldState.ts : "")) / 1000);
                            Gesamtzeit = 0;
                            Gesamtpulse = 0;
                            Zaehler = 1;
                            while (Gesamtzeit < 600 && Zaehler <= Zeitliste.length) {
                              Gesamtpulse = (typeof Gesamtpulse == 'number' ? Gesamtpulse : 0) + Liste[(Zaehler - 1)];
                              Gesamtzeit = (typeof Gesamtzeit == 'number' ? Gesamtzeit : 0) + Zeitliste[(Zaehler - 1)];
                              Zaehler = (typeof Zaehler == 'number' ? Zaehler : 0) + 1;
                            }
                            // durchschnittliche Anzahl von Pulsen pro Sekunde
                            // min. 1/120
                            setState("javascript.0.Gaszaehler.Impulse_600_Sek"/*Impulse_600_Sek*/, (Math.min(Math.max(Gesamtpulse / Gesamtzeit, 1 / 120), 1)), true);
                            if (Zaehler <= Zeitliste.length) {
                              Zeitliste = Zeitliste.slice(0, Zaehler);
                              Z_C3_A4hlerliste = Z_C3_A4hlerliste.slice(0, Zaehler);
                            }
                            console.log(getState("javascript.0.Gaszaehler.Impulse_600").val);
                          });
                          
                          
                          Asgothian 1 Reply Last reply Reply Quote 0
                          • Asgothian
                            Asgothian Developer @DasMoritz last edited by

                            @dasmoritz

                            Ok. Wald, Bäume, Einstellungen:

                            Screenshot 2021-11-11 at 11.38.30.png

                            An dieser Stelle muss der Punkt "Liste" auf "Zählerliste" umgestellt werden.

                            A.

                            D 1 Reply Last reply Reply Quote 0
                            • D
                              DasMoritz @Asgothian last edited by

                              @asgothian

                              Ich glaube wir haben einen "Durchbruch".
                              Es kommen nun nur noch gelbe Warnmeldungen:

                              72c6d94b-c18d-44b9-ab24-5775b468fb54-image.png

                              Der Datenpunkt Impulse_600_Sek wird auch beschrieben:
                              19928a29-3f41-4071-b6e2-1ed950dcbbc3-image.png

                              Alles andere ist "Rechnerei" (hoffe ich), dass sollte ich wohl hinbekommen.

                              Homoran Asgothian 2 Replies Last reply Reply Quote 0
                              • Homoran
                                Homoran Global Moderator Administrators @DasMoritz last edited by

                                @dasmoritz sagte in Gaszähler auswerten - Problem:

                                Es kommen nun nur noch gelbe Warnmeldungen:

                                Bitte als Text in Code-tags posten und dann mal in de js-Ansicht die entsprechende Stellen dazu posten (Zeile 29, Pos3 und Zeil 34, Pos 15)

                                1 Reply Last reply Reply Quote 0
                                • Asgothian
                                  Asgothian Developer @DasMoritz last edited by

                                  @dasmoritz
                                  Zumindest die 2. Warnung kann ich erklären - du hast einen debug Baustein mit einem Datenpunkt der wahrscheinlich nicht existiert oder nicht gefüllt ist

                                  Screenshot 2021-11-11 at 13.00.53.png

                                  Die erste ist mir noch nicht ganz klar.

                                  A.

                                  D 1 Reply Last reply Reply Quote 0
                                  • D
                                    DasMoritz @Asgothian last edited by

                                    @asgothian

                                    Moin,

                                    nun passiert gar nichts mehr, da die seit 12:07 Heizung aus ist.
                                    Müsste nicht zumindest in der grauen Theorie das Script weiterlaufen und damit den Wert "Impulse_600_Sek" immer weiter in Richtung 0,00 führen, jetzt wo die Heizung aus ist?

                                    Der Wert ist mit dem letzten Impuls bei 0,0267 stehen geblieben.
                                    d456d2ec-4dcf-4dc2-a308-7a569b912af8-image.png

                                    Danke,
                                    Moritz

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

                                      @dasmoritz
                                      Nach den 180 s muss neben "Brenner aktiv auf falsch" auch "Impulse_600_Sek auf 0" gesetzt werden.

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

                                        @paul53 Das macht absolut Sinn, ist eingebaut.

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

                                        Support us

                                        ioBroker
                                        Community Adapters
                                        Donate

                                        601
                                        Online

                                        31.7k
                                        Users

                                        79.7k
                                        Topics

                                        1.3m
                                        Posts

                                        6
                                        41
                                        2640
                                        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