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. Skripten / Logik
  4. Blockly
  5. Gaszähler auswerten - Problem

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    16
    1
    309

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    4.7k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.3k

Gaszähler auswerten - Problem

Scheduled Pinned Locked Moved Blockly
41 Posts 6 Posters 4.9k Views 4 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.
  • D DasMoritz

    @homoran

    Okay, dann beende ich mal mein bestehendes Script und starte das obenstehende.

    Das die ObjektID auf die Impulse referenziert die der Wemos D1 in den ioBroker schreibt ist korrekt?

    AsgothianA Offline
    AsgothianA Offline
    Asgothian
    Developer
    wrote on last edited by Asgothian
    #20

    @dasmoritz sagte in Gaszähler auswerten - Problem:

    Das die ObjektID auf die Impulse referenziert die der Wemos D1 in den ioBroker schreibt ist korrekt?

    Ja.

    Das ist die Objekt id für den Trigger.

    Nein - du musst 2 unterschiedliche Objekt-ID's auswählen.

    Eine für den Trigger, und eine wo die Werte aus der Umrechnung hinein sollen.

    A.

    sorry - hatte deinen Post missverstanden

    ioBroker auf RPi4 - Hardware soweit wie möglich via Zigbee.
    "Shit don't work" ist keine Fehlermeldung, sondern ein Fluch.

    D 1 Reply Last reply
    0
    • AsgothianA Asgothian

      @dasmoritz sagte in Gaszähler auswerten - Problem:

      Das die ObjektID auf die Impulse referenziert die der Wemos D1 in den ioBroker schreibt ist korrekt?

      Ja.

      Das ist die Objekt id für den Trigger.

      Nein - du musst 2 unterschiedliche Objekt-ID's auswählen.

      Eine für den Trigger, und eine wo die Werte aus der Umrechnung hinein sollen.

      A.

      sorry - hatte deinen Post missverstanden

      D Offline
      D Offline
      DasMoritz
      wrote on last edited by DasMoritz
      #21

      @asgothian

      Moin,

      nur damit ich es hier nun nicht versaue:
      Der Wemos D1 beschreibt autark folgenden DP über das Script, welches ich im Wemos D1 hochgeladen habe: (Datenpunkt = Impulse)

      30bbaddc-e4ac-492f-be55-7633268845e7-image.png

      Exakt diesen DP hänge ich dann bei "Falls mache" so ein, korrekt?
      e96cf71e-449c-435c-8e58-78a2065ecabe-image.png

      Zudem habe ich manuell den Datenpunkt "Impulse_600_Sek" angelegt (jener Datenpunkt, der mir anzeigt wieviele Impulse ich pro Sekunde innerhalb der letzten 600 Sekunden bekommen habe) , so korrekt?

      b5bcaf44-d3eb-4c37-aeb1-0885e0e5c91f-image.png

      Ergänzend gibt es zudem den manuellen Datenpunkt "Impulse_Scriptneu", in den ich die "Pulse pro Sekunde" schreibe korrekt?
      c18dc893-005a-42dc-a347-f59982bfe70d-image.png

      Das ganze sieht dann im Skript so aus:
      bdb12f40-3c9d-4453-8c69-5250cad9d41d-image.png

      Im Spoiler einmal das aktualisierte Skript:

      
      
       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[0] = (obj.state ? obj.state.val : "") - (obj.oldState ? obj.oldState.val : "");
        Zeitliste[0] = ((obj.state ? obj.state.ts : "") - (obj.oldState ? obj.oldState.ts : "")) / 1000;
        Gesamtzeit = 0;
        Gesamtpulse = 0;
        Zaehler = 1;
        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;
        }
        // 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);
        Zeitliste = Zeitliste.slice(0, Zaehler);
        Z_C3_A4hlerliste = Z_C3_A4hlerliste.slice(0, Zaehler);
        console.log(getState("javascript.0.Gaszaehler.Impulse_600").val);
      });
      

      Soweit in Ordnung?

      Danke :-)

      AsgothianA 1 Reply Last reply
      0
      • D DasMoritz

        @asgothian

        Moin,

        nur damit ich es hier nun nicht versaue:
        Der Wemos D1 beschreibt autark folgenden DP über das Script, welches ich im Wemos D1 hochgeladen habe: (Datenpunkt = Impulse)

        30bbaddc-e4ac-492f-be55-7633268845e7-image.png

        Exakt diesen DP hänge ich dann bei "Falls mache" so ein, korrekt?
        e96cf71e-449c-435c-8e58-78a2065ecabe-image.png

        Zudem habe ich manuell den Datenpunkt "Impulse_600_Sek" angelegt (jener Datenpunkt, der mir anzeigt wieviele Impulse ich pro Sekunde innerhalb der letzten 600 Sekunden bekommen habe) , so korrekt?

        b5bcaf44-d3eb-4c37-aeb1-0885e0e5c91f-image.png

        Ergänzend gibt es zudem den manuellen Datenpunkt "Impulse_Scriptneu", in den ich die "Pulse pro Sekunde" schreibe korrekt?
        c18dc893-005a-42dc-a347-f59982bfe70d-image.png

        Das ganze sieht dann im Skript so aus:
        bdb12f40-3c9d-4453-8c69-5250cad9d41d-image.png

        Im Spoiler einmal das aktualisierte Skript:

        
        
         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[0] = (obj.state ? obj.state.val : "") - (obj.oldState ? obj.oldState.val : "");
          Zeitliste[0] = ((obj.state ? obj.state.ts : "") - (obj.oldState ? obj.oldState.ts : "")) / 1000;
          Gesamtzeit = 0;
          Gesamtpulse = 0;
          Zaehler = 1;
          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;
          }
          // 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);
          Zeitliste = Zeitliste.slice(0, Zaehler);
          Z_C3_A4hlerliste = Z_C3_A4hlerliste.slice(0, Zaehler);
          console.log(getState("javascript.0.Gaszaehler.Impulse_600").val);
        });
        

        Soweit in Ordnung?

        Danke :-)

        AsgothianA Offline
        AsgothianA Offline
        Asgothian
        Developer
        wrote on last edited by
        #22

        @dasmoritz

        Fast, Auch an dieser Stelle solltest Du den State "Impulse_600_Sek" aktualisieren.
        Screenshot 2021-11-11 at 08.58.40.png

        Die da erwartete Zahl sollte zwischen 0.5 (Ein Impuls alle 2 Sekunden) und 0.00833 (Ein Impuls alle 120 Sekunden) liegen.

        Das müsstest Du für deine Darstellung dann noch in kW umrechnen.

        ioBroker auf RPi4 - Hardware soweit wie möglich via Zigbee.
        "Shit don't work" ist keine Fehlermeldung, sondern ein Fluch.

        D 1 Reply Last reply
        0
        • AsgothianA Asgothian

          @dasmoritz

          Fast, Auch an dieser Stelle solltest Du den State "Impulse_600_Sek" aktualisieren.
          Screenshot 2021-11-11 at 08.58.40.png

          Die da erwartete Zahl sollte zwischen 0.5 (Ein Impuls alle 2 Sekunden) und 0.00833 (Ein Impuls alle 120 Sekunden) liegen.

          Das müsstest Du für deine Darstellung dann noch in kW umrechnen.

          D Offline
          D Offline
          DasMoritz
          wrote on last edited by
          #23

          @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

          AsgothianA 1 Reply Last reply
          0
          • D DasMoritz

            @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

            AsgothianA Offline
            AsgothianA Offline
            Asgothian
            Developer
            wrote on last edited by
            #24

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

            ioBroker auf RPi4 - Hardware soweit wie möglich via Zigbee.
            "Shit don't work" ist keine Fehlermeldung, sondern ein Fluch.

            D 1 Reply Last reply
            0
            • AsgothianA Asgothian

              @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 Offline
              D Offline
              DasMoritz
              wrote on last edited by
              #25

              @asgothian

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

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

              AsgothianA 1 Reply Last reply
              0
              • T Offline
                T Offline
                tomba0815
                wrote on last edited by tomba0815
                #26

                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
                0
                • T 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 Offline
                  D Offline
                  DasMoritz
                  wrote on last edited by
                  #27

                  @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
                  0
                  • D DasMoritz

                    @asgothian

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

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

                    AsgothianA Offline
                    AsgothianA Offline
                    Asgothian
                    Developer
                    wrote on last edited by
                    #28

                    @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

                    ioBroker auf RPi4 - Hardware soweit wie möglich via Zigbee.
                    "Shit don't work" ist keine Fehlermeldung, sondern ein Fluch.

                    D 1 Reply Last reply
                    0
                    • AsgothianA Asgothian

                      @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 Offline
                      D Offline
                      DasMoritz
                      wrote on last edited by
                      #29

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

                      AsgothianA 1 Reply Last reply
                      0
                      • D DasMoritz

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

                        AsgothianA Offline
                        AsgothianA Offline
                        Asgothian
                        Developer
                        wrote on last edited by
                        #30

                        @dasmoritz zeig nochmal das ganze Skript

                        A.

                        ioBroker auf RPi4 - Hardware soweit wie möglich via Zigbee.
                        "Shit don't work" ist keine Fehlermeldung, sondern ein Fluch.

                        D 1 Reply Last reply
                        0
                        • AsgothianA Asgothian

                          @dasmoritz zeig nochmal das ganze Skript

                          A.

                          D Offline
                          D Offline
                          DasMoritz
                          wrote on last edited by
                          #31

                          @asgothian

                          Da ist es :-)

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

                          AsgothianA paul53P 2 Replies Last reply
                          0
                          • D DasMoritz

                            @asgothian

                            Da ist es :-)

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

                            AsgothianA Offline
                            AsgothianA Offline
                            Asgothian
                            Developer
                            wrote on last edited by Asgothian
                            #32

                            @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

                            ioBroker auf RPi4 - Hardware soweit wie möglich via Zigbee.
                            "Shit don't work" ist keine Fehlermeldung, sondern ein Fluch.

                            D 1 Reply Last reply
                            0
                            • D DasMoritz

                              @asgothian

                              Da ist es :-)

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

                              paul53P Offline
                              paul53P Offline
                              paul53
                              wrote on last edited by
                              #33

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

                              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
                              • AsgothianA 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 Offline
                                D Offline
                                DasMoritz
                                wrote on last edited by
                                #34

                                @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);
                                });
                                
                                
                                AsgothianA 1 Reply Last reply
                                0
                                • D DasMoritz

                                  @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);
                                  });
                                  
                                  
                                  AsgothianA Offline
                                  AsgothianA Offline
                                  Asgothian
                                  Developer
                                  wrote on last edited by
                                  #35

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

                                  ioBroker auf RPi4 - Hardware soweit wie möglich via Zigbee.
                                  "Shit don't work" ist keine Fehlermeldung, sondern ein Fluch.

                                  D 1 Reply Last reply
                                  0
                                  • AsgothianA Asgothian

                                    @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 Offline
                                    D Offline
                                    DasMoritz
                                    wrote on last edited by
                                    #36

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

                                    HomoranH AsgothianA 2 Replies Last reply
                                    0
                                    • D DasMoritz

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

                                      HomoranH Do not disturb
                                      HomoranH Do not disturb
                                      Homoran
                                      Global Moderator Administrators
                                      wrote on last edited by
                                      #37

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

                                      kein Support per PN! - Fragen im Forum stellen -
                                      Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                                      Das Forum freut sich über eine Spende. Benutzt dazu den Spendenbutton im Header. Danke!
                                      der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                                      1 Reply Last reply
                                      0
                                      • D DasMoritz

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

                                        AsgothianA Offline
                                        AsgothianA Offline
                                        Asgothian
                                        Developer
                                        wrote on last edited by
                                        #38

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

                                        ioBroker auf RPi4 - Hardware soweit wie möglich via Zigbee.
                                        "Shit don't work" ist keine Fehlermeldung, sondern ein Fluch.

                                        D 1 Reply Last reply
                                        0
                                        • AsgothianA Asgothian

                                          @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 Offline
                                          D Offline
                                          DasMoritz
                                          wrote on last edited by
                                          #39

                                          @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

                                          paul53P 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

                                          577

                                          Online

                                          32.7k

                                          Users

                                          82.5k

                                          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