Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Blockly
  5. Betriebsstundenzähler funktioniert nicht

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.6k

Betriebsstundenzähler funktioniert nicht

Geplant Angeheftet Gesperrt Verschoben Blockly
blockly
30 Beiträge 4 Kommentatoren 2.8k Aufrufe 4 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • G G.Hawk

    @paul53
    Ich frage mich wo der die Daten her nimmt um diese Betriebszeit zu berechnen.
    Ich habe einen eigenen Datenpunkt angelegt der ja auch schon beschrieben wurde aber auf einmal wird er nicht mehr beschrieben.

    Mit dem Gerät meine ich den Schaltaktor.
    Irgendwo muss doch gespeichert werden wann der das letzte Mal an war.
    Sonst könnte das Script ja nichts berechnen.

    paul53P Offline
    paul53P Offline
    paul53
    schrieb am zuletzt editiert von paul53
    #16

    @Martin-0 sagte:

    Ich frage mich wo der die Daten her nimmt um diese Betriebszeit zu berechnen.

    "letzte Änderung" (state.lc) ist eine Eigenschaft des Zustands eines jeden Datenpunktes.

    @Martin-0 sagte in Betriebsstundenzähler funktioniert nicht:

    Mit dem Gerät meine ich den Schaltaktor. Irgendwo muss doch gespeichert werden wann der das letzte Mal an war.

    Wechsle im Tab "Objekte" mal in die Statusansicht, dann siehst Du den Zeitpunkt des letzten Schaltens des Aktors.

    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

    G 1 Antwort Letzte Antwort
    0
    • paul53P paul53

      @Martin-0 sagte:

      Ich frage mich wo der die Daten her nimmt um diese Betriebszeit zu berechnen.

      "letzte Änderung" (state.lc) ist eine Eigenschaft des Zustands eines jeden Datenpunktes.

      @Martin-0 sagte in Betriebsstundenzähler funktioniert nicht:

      Mit dem Gerät meine ich den Schaltaktor. Irgendwo muss doch gespeichert werden wann der das letzte Mal an war.

      Wechsle im Tab "Objekte" mal in die Statusansicht, dann siehst Du den Zeitpunkt des letzten Schaltens des Aktors.

      G Offline
      G Offline
      G.Hawk
      schrieb am zuletzt editiert von
      #17

      @paul53
      Screenshot_20200831-223335_Chrome.jpg

      paul53P 1 Antwort Letzte Antwort
      0
      • G G.Hawk

        @paul53
        Screenshot_20200831-223335_Chrome.jpg

        paul53P Offline
        paul53P Offline
        paul53
        schrieb am zuletzt editiert von
        #18

        @Martin-0
        Objekte_Status.JPG

        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

        G 1 Antwort Letzte Antwort
        0
        • paul53P paul53

          @Martin-0
          Objekte_Status.JPG

          G Offline
          G Offline
          G.Hawk
          schrieb am zuletzt editiert von
          #19

          @paul53
          Wie wechselt man denn zu der Anzeige?

          paul53P 1 Antwort Letzte Antwort
          0
          • G G.Hawk

            @paul53
            Wie wechselt man denn zu der Anzeige?

            paul53P Offline
            paul53P Offline
            paul53
            schrieb am zuletzt editiert von
            #20

            @Martin-0 sagte:

            Wie wechselt man denn zu der Anzeige?

            Oben, fünftes Symbol von links.

            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

            G 1 Antwort Letzte Antwort
            0
            • paul53P paul53

              @Martin-0 sagte:

              Wie wechselt man denn zu der Anzeige?

              Oben, fünftes Symbol von links.

              G Offline
              G Offline
              G.Hawk
              schrieb am zuletzt editiert von
              #21

              @paul53
              Da sind überall Daten drin
              Sonst lösche ich das Skript und schreib es noch mal

              paul53P 1 Antwort Letzte Antwort
              0
              • G G.Hawk

                @paul53
                Da sind überall Daten drin
                Sonst lösche ich das Skript und schreib es noch mal

                paul53P Offline
                paul53P Offline
                paul53
                schrieb am zuletzt editiert von paul53
                #22

                @Martin-0 sagte:

                Sonst lösche ich das Skript und schreib es noch mal

                Poste vorher mal den erzeugten Javascript-Code ohne die letzte Zeile in Code tags.

                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

                G 1 Antwort Letzte Antwort
                0
                • paul53P paul53

                  @Martin-0 sagte:

                  Sonst lösche ich das Skript und schreib es noch mal

                  Poste vorher mal den erzeugten Javascript-Code ohne die letzte Zeile in Code tags.

                  G Offline
                  G Offline
                  G.Hawk
                  schrieb am zuletzt editiert von
                  #23

                  @paul53
                  Was ist die letzte Zeile?

                  paul53P 1 Antwort Letzte Antwort
                  0
                  • G G.Hawk

                    @paul53
                    Was ist die letzte Zeile?

                    paul53P Offline
                    paul53P Offline
                    paul53
                    schrieb am zuletzt editiert von paul53
                    #24

                    @Martin-0 sagte:

                    Was ist die letzte Zeile?

                    Wenn du in die Javascript-Ansicht wechselst, siehst Du unten eine ewig lange Zeile mit XML-Code. Die Zeile lass bitte weg.

                    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

                    G 2 Antworten Letzte Antwort
                    0
                    • paul53P paul53

                      @Martin-0 sagte:

                      Was ist die letzte Zeile?

                      Wenn du in die Javascript-Ansicht wechselst, siehst Du unten eine ewig lange Zeile mit XML-Code. Die Zeile lass bitte weg.

                      G Offline
                      G Offline
                      G.Hawk
                      schrieb am zuletzt editiert von
                      #25

                      @paul53 ```
                      code_text

                      
                      
                      on({id: 'hm-rpc.0.JEQ0063840.1.STATE', change: "lt", ack: false}, function (obj) {
                        var value = obj.state.val;
                        var oldValue = obj.oldState.val;
                        timeout4 = setTimeout(function () {
                          Einschaltdauer_S_C3_BCd = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                          setState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd"/*Betriebsstundenzähler Süd*/, Einschaltdauer_S_C3_BCd);
                          timeout = setTimeout(function () {
                            setState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd"/*Betriebsstundenzähler Süd*/, Math.round(getState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd").val*10)/10);
                          }, 10000);
                        }, 5000);
                      });
                      
                      on({id: "hm-rpc.0.JEQ0063840.2.STATE"/*Bewässerung West.STATE*/, change: "lt", ack: false}, function (obj) {
                        var value = obj.state.val;
                        var oldValue = obj.oldState.val;
                        Einschaltdauer_West = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                        setState("hm-rpc.0.JEQ0063840.2.STATE"/*Bewässerung West.STATE*/, Einschaltdauer_West, true);
                      });
                      
                      on({id: "hm-rpc.0.JEQ0063840.3.STATE"/*Bewässerung Nord.STATE*/, val: false, ack: false}, function (obj) {
                        var value = obj.state.val;
                        var oldValue = obj.oldState.val;
                        timeout6 = setTimeout(function () {
                          Einschaltdauer_Nord = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                          setState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord"/*Betreibstundenzähler Nord*/, Einschaltdauer_Nord);
                          timeout3 = setTimeout(function () {
                            setState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord"/*Betreibstundenzähler Nord*/, Math.round(getState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord").val*10)/10);
                          }, 10000);
                        }, 5000);
                      });
                      1 Antwort Letzte Antwort
                      0
                      • paul53P paul53

                        @Martin-0 sagte:

                        Was ist die letzte Zeile?

                        Wenn du in die Javascript-Ansicht wechselst, siehst Du unten eine ewig lange Zeile mit XML-Code. Die Zeile lass bitte weg.

                        G Offline
                        G Offline
                        G.Hawk
                        schrieb am zuletzt editiert von
                        #26

                        @paul53

                        var timeout2, timeout4, Einschaltdauer_West, timeout6, Einschaltdauer_S_C3_BCd, Einschaltdauer_Nord, timeout, timeout3;
                        
                        
                        on({id: 'hm-rpc.0.JEQ0063840.1.STATE', change: "lt", ack: false}, function (obj) {
                          var value = obj.state.val;
                          var oldValue = obj.oldState.val;
                          timeout4 = setTimeout(function () {
                            Einschaltdauer_S_C3_BCd = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                            setState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd"/*Betriebsstundenzähler Süd*/, Einschaltdauer_S_C3_BCd);
                            timeout = setTimeout(function () {
                              setState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd"/*Betriebsstundenzähler Süd*/, Math.round(getState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd").val*10)/10);
                            }, 10000);
                          }, 5000);
                        });
                        
                        on({id: "hm-rpc.0.JEQ0063840.2.STATE"/*Bewässerung West.STATE*/, change: "lt", ack: false}, function (obj) {
                          var value = obj.state.val;
                          var oldValue = obj.oldState.val;
                          Einschaltdauer_West = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                          setState("hm-rpc.0.JEQ0063840.2.STATE"/*Bewässerung West.STATE*/, Einschaltdauer_West, true);
                        });
                        
                        on({id: "hm-rpc.0.JEQ0063840.3.STATE"/*Bewässerung Nord.STATE*/, val: false, ack: false}, function (obj) {
                          var value = obj.state.val;
                          var oldValue = obj.oldState.val;
                          timeout6 = setTimeout(function () {
                            Einschaltdauer_Nord = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                            setState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord"/*Betreibstundenzähler Nord*/, Einschaltdauer_Nord);
                            timeout3 = setTimeout(function () {
                              setState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord"/*Betreibstundenzähler Nord*/, Math.round(getState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord").val*10)/10);
                            }, 10000);
                          }, 5000);
                        });
                        
                        
                        G 1 Antwort Letzte Antwort
                        0
                        • G G.Hawk

                          @paul53

                          var timeout2, timeout4, Einschaltdauer_West, timeout6, Einschaltdauer_S_C3_BCd, Einschaltdauer_Nord, timeout, timeout3;
                          
                          
                          on({id: 'hm-rpc.0.JEQ0063840.1.STATE', change: "lt", ack: false}, function (obj) {
                            var value = obj.state.val;
                            var oldValue = obj.oldState.val;
                            timeout4 = setTimeout(function () {
                              Einschaltdauer_S_C3_BCd = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                              setState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd"/*Betriebsstundenzähler Süd*/, Einschaltdauer_S_C3_BCd);
                              timeout = setTimeout(function () {
                                setState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd"/*Betriebsstundenzähler Süd*/, Math.round(getState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd").val*10)/10);
                              }, 10000);
                            }, 5000);
                          });
                          
                          on({id: "hm-rpc.0.JEQ0063840.2.STATE"/*Bewässerung West.STATE*/, change: "lt", ack: false}, function (obj) {
                            var value = obj.state.val;
                            var oldValue = obj.oldState.val;
                            Einschaltdauer_West = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                            setState("hm-rpc.0.JEQ0063840.2.STATE"/*Bewässerung West.STATE*/, Einschaltdauer_West, true);
                          });
                          
                          on({id: "hm-rpc.0.JEQ0063840.3.STATE"/*Bewässerung Nord.STATE*/, val: false, ack: false}, function (obj) {
                            var value = obj.state.val;
                            var oldValue = obj.oldState.val;
                            timeout6 = setTimeout(function () {
                              Einschaltdauer_Nord = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                              setState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord"/*Betreibstundenzähler Nord*/, Einschaltdauer_Nord);
                              timeout3 = setTimeout(function () {
                                setState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord"/*Betreibstundenzähler Nord*/, Math.round(getState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord").val*10)/10);
                              }, 10000);
                            }, 5000);
                          });
                          
                          
                          G Offline
                          G Offline
                          G.Hawk
                          schrieb am zuletzt editiert von
                          #27

                          Das war nix

                          G 1 Antwort Letzte Antwort
                          0
                          • G G.Hawk

                            Das war nix

                            G Offline
                            G Offline
                            G.Hawk
                            schrieb am zuletzt editiert von G.Hawk
                            #28
                            var Einschaltdauer_S_C3_BCd, Einschaltdauer_West, Einschaltdauer_Nord;
                            
                            
                            on({id: 'hm-rpc.0.JEQ0063840.1.STATE', change: "lt", ack: false}, function (obj) {
                              var value = obj.state.val;
                              var oldValue = obj.oldState.val;
                              Einschaltdauer_S_C3_BCd = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                              setState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd"/*Betriebsstundenzähler Süd*/, Einschaltdauer_S_C3_BCd);
                              setState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd"/*Betriebsstundenzähler Süd*/, Math.round(getState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd").val*10)/10);
                            });
                            
                            on({id: "hm-rpc.0.JEQ0063840.2.STATE"/*Bewässerung West.STATE*/, change: "lt", ack: false}, function (obj) {
                              var value = obj.state.val;
                              var oldValue = obj.oldState.val;
                              Einschaltdauer_West = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                              setState("hm-rpc.0.JEQ0063840.2.STATE"/*Bewässerung West.STATE*/, Einschaltdauer_West, true);
                              setState("hm-rpc.0.JEQ0063840.2.STATE"/*Bewässerung West.STATE*/, Math.round(getState("javascript.0.Bewaesserung.Betriebsstundenzähler_West").val*10)/10, true);
                            });
                            
                            on({id: "hm-rpc.0.JEQ0063840.3.STATE"/*Bewässerung Nord.STATE*/, val: false, ack: false}, function (obj) {
                              var value = obj.state.val;
                              var oldValue = obj.oldState.val;
                              Einschaltdauer_Nord = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                              setState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord"/*Betreibstundenzähler Nord*/, Einschaltdauer_Nord);
                              setState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord"/*Betreibstundenzähler Nord*/, Math.round(getState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord").val*10)/10);
                            

                            So

                            paul53P 1 Antwort Letzte Antwort
                            0
                            • G G.Hawk
                              var Einschaltdauer_S_C3_BCd, Einschaltdauer_West, Einschaltdauer_Nord;
                              
                              
                              on({id: 'hm-rpc.0.JEQ0063840.1.STATE', change: "lt", ack: false}, function (obj) {
                                var value = obj.state.val;
                                var oldValue = obj.oldState.val;
                                Einschaltdauer_S_C3_BCd = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                                setState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd"/*Betriebsstundenzähler Süd*/, Einschaltdauer_S_C3_BCd);
                                setState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd"/*Betriebsstundenzähler Süd*/, Math.round(getState("javascript.0.Bewaesserung.Betriebsstundenzähler_Süd").val*10)/10);
                              });
                              
                              on({id: "hm-rpc.0.JEQ0063840.2.STATE"/*Bewässerung West.STATE*/, change: "lt", ack: false}, function (obj) {
                                var value = obj.state.val;
                                var oldValue = obj.oldState.val;
                                Einschaltdauer_West = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                                setState("hm-rpc.0.JEQ0063840.2.STATE"/*Bewässerung West.STATE*/, Einschaltdauer_West, true);
                                setState("hm-rpc.0.JEQ0063840.2.STATE"/*Bewässerung West.STATE*/, Math.round(getState("javascript.0.Bewaesserung.Betriebsstundenzähler_West").val*10)/10, true);
                              });
                              
                              on({id: "hm-rpc.0.JEQ0063840.3.STATE"/*Bewässerung Nord.STATE*/, val: false, ack: false}, function (obj) {
                                var value = obj.state.val;
                                var oldValue = obj.oldState.val;
                                Einschaltdauer_Nord = ((obj.state ? obj.state.lc : "") - (obj.oldState ? obj.oldState.lc : "")) / 60000;
                                setState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord"/*Betreibstundenzähler Nord*/, Einschaltdauer_Nord);
                                setState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord"/*Betreibstundenzähler Nord*/, Math.round(getState("javascript.0.Bewaesserung.Betreibstundenzähler_Nord").val*10)/10);
                              

                              So

                              paul53P Offline
                              paul53P Offline
                              paul53
                              schrieb am zuletzt editiert von paul53
                              #29

                              @Martin-0

                              1. Bei "Bewässerung West" wird in den falschen Datenpunkt geschrieben.
                              2. Man kann nicht erst den nicht gerundeten Wert in einen Datenpunkt schreiben, diesen anschließend wieder auslesen und anschließend den gerundeten Wert zurück schreiben, da das Schreiben asynchron erfolgt, d.h. noch nicht fertig ist, wenn der Wert wieder eingelesen wird.
                                Richtig: Den Wert der Variablen gerundet in den Datenpunkt schreiben:

                              Blockly_temp.JPG

                              Meinen Vorschlag hast Du offenbar ignoriert.

                              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 Antwort Letzte Antwort
                              0
                              • paul53P paul53

                                @Martin-0
                                Sollte die Betriebsdauer nicht kumulativ erfasst werden ?
                                Wozu sind die Timeouts gut ?
                                Vorschlag:

                                Blockly_temp.JPG

                                G Offline
                                G Offline
                                G.Hawk
                                schrieb am zuletzt editiert von
                                #30

                                @paul53
                                Es läuft einwandfrei.
                                Danke

                                1 Antwort Letzte Antwort
                                0
                                Antworten
                                • In einem neuen Thema antworten
                                Anmelden zum Antworten
                                • Älteste zuerst
                                • Neuste zuerst
                                • Meiste Stimmen


                                Support us

                                ioBroker
                                Community Adapters
                                Donate

                                635

                                Online

                                32.7k

                                Benutzer

                                82.4k

                                Themen

                                1.3m

                                Beiträge
                                Community
                                Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                ioBroker Community 2014-2025
                                logo
                                • Anmelden

                                • Du hast noch kein Konto? Registrieren

                                • Anmelden oder registrieren, um zu suchen
                                • Erster Beitrag
                                  Letzter Beitrag
                                0
                                • Home
                                • Aktuell
                                • Tags
                                • Ungelesen 0
                                • Kategorien
                                • Unreplied
                                • Beliebt
                                • GitHub
                                • Docu
                                • Hilfe