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. JavaScript
  5. Gelöst: Script Fehler

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.1k

Gelöst: Script Fehler

Geplant Angeheftet Gesperrt Verschoben JavaScript
javascript
19 Beiträge 2 Kommentatoren 624 Aufrufe 3 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.
  • M Offline
    M Offline
    michihorn
    schrieb am zuletzt editiert von michihorn
    #1

    Hallo
    ich sehe gerade den Wald vor Bäumen nicht.
    Bekomme folgende Fehlermeldung:
    Unbenannt11.JPG

    Der Code sieht so aus:
    Unbenannt10.JPG

    Unterhalb von Zeile 25 ist nichts.
    Gruß
    Michael

    paul53P 1 Antwort Letzte Antwort
    0
    • M michihorn

      Hallo
      ich sehe gerade den Wald vor Bäumen nicht.
      Bekomme folgende Fehlermeldung:
      Unbenannt11.JPG

      Der Code sieht so aus:
      Unbenannt10.JPG

      Unterhalb von Zeile 25 ist nichts.
      Gruß
      Michael

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

      @michihorn sagte:

      Unterhalb von Zeile 25 ist nichts.

      Dann fehlen die schließenden geschweiften Klammern zu

      if (AUS === true) {
      

      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

      M 1 Antwort Letzte Antwort
      0
      • paul53P paul53

        @michihorn sagte:

        Unterhalb von Zeile 25 ist nichts.

        Dann fehlen die schließenden geschweiften Klammern zu

        if (AUS === true) {
        
        M Offline
        M Offline
        michihorn
        schrieb am zuletzt editiert von
        #3

        @paul53 sagte in Script Fehler:

        @michihorn sagte:

        Unterhalb von Zeile 25 ist nichts.

        Dann fehlen die schließenden geschweiften Klammern zu

        if (AUS === true) {
        

        Jau, ich sach ja, hab den Wald vor Bäumen nicht gesehen. THX

        1 Antwort Letzte Antwort
        0
        • M Offline
          M Offline
          michihorn
          schrieb am zuletzt editiert von
          #4

          @paul53 :
          Kannst Du mir sagen warum das Script nicht auf Veränderung von idStrom reagiert?
          Gruß Michael

          // Hans Status
          const idHans = 'hm-rpc.2.0001D8A991F432.3.STATE'
          createState("javascript.0.Haus.Hans.StatusWert");
          createState("javascript.0.Haus.Hans.Status");
          var HansStatusWert = 'javascript.0.Haus.Hans.StatusWert'
          var HansStatus = 'javascript.0.Haus.Hans.Status'
          var idStrom = getState('hm-rpc.2.0001D8A991F432.6.CURRENT').val;
          var AUS = getState(idHans).val;
          var Status;
          
          on({ id: idStrom, change: 'ne'}, function (obj){
          //schedule("*/1 * * * *", function () {
              if (idStrom == 0) {
                  setState(HansStatusWert, 0);
                  setState(HansStatus, "AUS");
                  log("AUS");
                  }
              
              if (idStrom >= 30 && idStrom <=60) {
                  setState(HansStatusWert, 2);
                  setState(HansStatus, "LÄUFT");
                  log("LÄUFT");
              }
              if (idStrom >= 70 && idStrom <=300) {
                  setState(HansStatusWert, 3);
                  setState(HansStatus, "LÄDT");
              }
              if (idStrom >= 65 && idStrom <=69) {
                  setState(HansStatusWert, 4);
                  setState(HansStatus, "Bereit");
                  log("BEREIT");
              }
                  if (getState(idHans).val == false) {
                  setState(HansStatusWert, 0);
                  setState(HansStatus, "AUS");
                  log("AUS");
                  }
          });
          
          paul53P 1 Antwort Letzte Antwort
          0
          • M michihorn

            @paul53 :
            Kannst Du mir sagen warum das Script nicht auf Veränderung von idStrom reagiert?
            Gruß Michael

            // Hans Status
            const idHans = 'hm-rpc.2.0001D8A991F432.3.STATE'
            createState("javascript.0.Haus.Hans.StatusWert");
            createState("javascript.0.Haus.Hans.Status");
            var HansStatusWert = 'javascript.0.Haus.Hans.StatusWert'
            var HansStatus = 'javascript.0.Haus.Hans.Status'
            var idStrom = getState('hm-rpc.2.0001D8A991F432.6.CURRENT').val;
            var AUS = getState(idHans).val;
            var Status;
            
            on({ id: idStrom, change: 'ne'}, function (obj){
            //schedule("*/1 * * * *", function () {
                if (idStrom == 0) {
                    setState(HansStatusWert, 0);
                    setState(HansStatus, "AUS");
                    log("AUS");
                    }
                
                if (idStrom >= 30 && idStrom <=60) {
                    setState(HansStatusWert, 2);
                    setState(HansStatus, "LÄUFT");
                    log("LÄUFT");
                }
                if (idStrom >= 70 && idStrom <=300) {
                    setState(HansStatusWert, 3);
                    setState(HansStatus, "LÄDT");
                }
                if (idStrom >= 65 && idStrom <=69) {
                    setState(HansStatusWert, 4);
                    setState(HansStatus, "Bereit");
                    log("BEREIT");
                }
                    if (getState(idHans).val == false) {
                    setState(HansStatusWert, 0);
                    setState(HansStatus, "AUS");
                    log("AUS");
                    }
            });
            
            paul53P Offline
            paul53P Offline
            paul53
            schrieb am zuletzt editiert von
            #5

            @michihorn sagte:

            warum das Script nicht auf Veränderung von idStrom reagiert?

            Ja, Zeile 7: idStrom ist keine ID, sondern der Wert des Datenpunktes.

            Im Trigger muss idStrom gegen obj.state.val getauscht werden.

            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
            • M Offline
              M Offline
              michihorn
              schrieb am zuletzt editiert von
              #6

              Kannst Du mir zeigen wie ich das Script umbauen muß?

              paul53P 1 Antwort Letzte Antwort
              0
              • M michihorn

                Kannst Du mir zeigen wie ich das Script umbauen muß?

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

                @michihorn

                // Hans Status
                const idHans = 'hm-rpc.2.0001D8A991F432.3.STATE';
                const idStrom = 'hm-rpc.2.0001D8A991F432.6.CURRENT';
                const HansStatusWert = 'Haus.Hans.StatusWert';
                const HansStatus = 'Haus.Hans.Status';
                
                createState(HansStatusWert, 0, {type: 'number'});
                createState(HansStatus, 'AUS', {type: 'string'});
                
                function Hans(strom) {
                    if (strom == 0) {
                        setState(HansStatusWert, 0, true);
                        setState(HansStatus, "AUS", true);
                        log("AUS");
                    }
                    if (strom >= 30 && strom <=60) {
                        setState(HansStatusWert, 2, true);
                        setState(HansStatus, "LÄUFT", true);
                        log("LÄUFT");
                    }
                    if (strom >= 70 && strom <= 300) {
                        setState(HansStatusWert, 3, true);
                        setState(HansStatus, "LÄDT", true);
                    }
                    if (strom >= 65 && strom <= 69) {
                        setState(HansStatusWert, 4, true);
                        setState(HansStatus, "Bereit", true);
                        log("BEREIT");
                    }
                    if (getState(idHans).val == false) {
                        setState(HansStatusWert, 0, true);
                        setState(HansStatus, "AUS", true);
                        log("AUS");
                    }
                }
                
                on(idStrom, function(obj) { // triggert bei Wertänderung
                    Hans(obj.state.val);
                });
                
                Hans(getState(idStrom).val); // Skriptstart 
                

                Lösche vorher die beiden Datenpunkte unter "javascript.0".

                EDIT: Logik in die Funktion Hans(strom) gepackt, die auch bei Skriptstart aufgerufen wird.

                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
                • M Offline
                  M Offline
                  michihorn
                  schrieb am zuletzt editiert von
                  #8

                  @paul53 sagte in Gelöst: Script Fehler:

                                                                                                                                              // Hans Status                                                                                                                                                                            const idHans = 'hm-rpc.2.0001D8A991F432.3.STATE';                                                                                                                                                                            const idStrom = 'hm-rpc.2.0001D8A991F432.6.CURRENT';                                                                                                                                                                            const HansStatusWert = 'Haus.Hans.StatusWert';                                                                                                                                                                            const HansStatus = 'Haus.Hans.Status';                                                                                                                                                                                                                                                                                                                                                         createState(HansStatusWert, 0, {type: 'number'});                                                                                                                                                                            createState(HansStatus, 'AUS', {type: 'string'});                                                                                                                                                                                                                                                                                                                                                         on(idStrom, function(obj) {                                                                                                                                                                                var strom = obj.state.val;                                                                                                                                                                                if (strom == 0) {                                                                                                                                                                                    setState(HansStatusWert, 0, true);                                                                                                                                                                                    setState(HansStatus, "AUS", true);                                                                                                                                                                                    log("AUS");                                                                                                                                                                                }                                                                                                                                                                                if (strom >= 30 && strom <=60) {                                                                                                                                                                                    setState(HansStatusWert, 2, true);                                                                                                                                                                                    setState(HansStatus, "LÄUFT", true);                                                                                                                                                                                    log("LÄUFT");                                                                                                                                                                                }                                                                                                                                                                                if (strom >= 70 && strom <= 300) {                                                                                                                                                                                    setState(HansStatusWert, 3, true);                                                                                                                                                                                    setState(HansStatus, "LÄDT", true);                                                                                                                                                                                }                                                                                                                                                                                if (strom >= 65 && strom <= 69) {                                                                                                                                                                                    setState(HansStatusWert, 4, true);                                                                                                                                                                                    setState(HansStatus, "Bereit", true);                                                                                                                                                                                    log("BEREIT");                                                                                                                                                                                }                                                                                                                                                                                if (getState(idHans).val == false) {                                                                                                                                                                                    setState(HansStatusWert, 0, true);                                                                                                                                                                                    setState(HansStatus, "AUS", true);                                                                                                                                                                                    log("AUS");                                                                                                                                                                                }                                                                                                                                                                            });
                  

                  Funktioniert nicht wie erwartet, derzeit werden 36mA gemessen. Das Script hat aber den Status auf AUS gesetzt.

                  paul53P 1 Antwort Letzte Antwort
                  0
                  • M michihorn

                    @paul53 sagte in Gelöst: Script Fehler:

                                                                                                                                                // Hans Status                                                                                                                                                                            const idHans = 'hm-rpc.2.0001D8A991F432.3.STATE';                                                                                                                                                                            const idStrom = 'hm-rpc.2.0001D8A991F432.6.CURRENT';                                                                                                                                                                            const HansStatusWert = 'Haus.Hans.StatusWert';                                                                                                                                                                            const HansStatus = 'Haus.Hans.Status';                                                                                                                                                                                                                                                                                                                                                         createState(HansStatusWert, 0, {type: 'number'});                                                                                                                                                                            createState(HansStatus, 'AUS', {type: 'string'});                                                                                                                                                                                                                                                                                                                                                         on(idStrom, function(obj) {                                                                                                                                                                                var strom = obj.state.val;                                                                                                                                                                                if (strom == 0) {                                                                                                                                                                                    setState(HansStatusWert, 0, true);                                                                                                                                                                                    setState(HansStatus, "AUS", true);                                                                                                                                                                                    log("AUS");                                                                                                                                                                                }                                                                                                                                                                                if (strom >= 30 && strom <=60) {                                                                                                                                                                                    setState(HansStatusWert, 2, true);                                                                                                                                                                                    setState(HansStatus, "LÄUFT", true);                                                                                                                                                                                    log("LÄUFT");                                                                                                                                                                                }                                                                                                                                                                                if (strom >= 70 && strom <= 300) {                                                                                                                                                                                    setState(HansStatusWert, 3, true);                                                                                                                                                                                    setState(HansStatus, "LÄDT", true);                                                                                                                                                                                }                                                                                                                                                                                if (strom >= 65 && strom <= 69) {                                                                                                                                                                                    setState(HansStatusWert, 4, true);                                                                                                                                                                                    setState(HansStatus, "Bereit", true);                                                                                                                                                                                    log("BEREIT");                                                                                                                                                                                }                                                                                                                                                                                if (getState(idHans).val == false) {                                                                                                                                                                                    setState(HansStatusWert, 0, true);                                                                                                                                                                                    setState(HansStatus, "AUS", true);                                                                                                                                                                                    log("AUS");                                                                                                                                                                                }                                                                                                                                                                            });
                    

                    Funktioniert nicht wie erwartet, derzeit werden 36mA gemessen. Das Script hat aber den Status auf AUS gesetzt.

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

                    @michihorn sagte:

                    Das Script hat aber den Status auf AUS gesetzt.

                    Das macht es auch, wenn der Datenpunkt von idHans den Wert false hat. Wenn noch nichts im Log steht, hat sich der Wert noch nicht verändert.

                    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
                    • M Offline
                      M Offline
                      michihorn
                      schrieb am zuletzt editiert von
                      #10

                      Der Datenpunkt ist auf TRUE, denn der Schalter ist für das Ladegerät zuständig und der Ruhestrom ist aktuell 36mA

                      paul53P M 2 Antworten Letzte Antwort
                      0
                      • M michihorn

                        Der Datenpunkt ist auf TRUE, denn der Schalter ist für das Ladegerät zuständig und der Ruhestrom ist aktuell 36mA

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

                        @michihorn sagte:

                        der Ruhestrom ist aktuell 36mA

                        Konstant oder um 36 mA schwankend ? Es wird erst getriggert, wenn sich der Wert ändert.

                        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
                        • M michihorn

                          Der Datenpunkt ist auf TRUE, denn der Schalter ist für das Ladegerät zuständig und der Ruhestrom ist aktuell 36mA

                          M Offline
                          M Offline
                          michihorn
                          schrieb am zuletzt editiert von
                          #12

                          @michihorn sagte in Gelöst: Script Fehler:

                          Der Datenpunkt ist auf TRUE, denn der Schalter ist für das Ladegerät zuständig und der Ruhestrom ist aktuell 36mA

                          Hier sollte in der VAR Strom eigendlich 36mA stehen.
                          Unbenannt3.JPG
                          Wenn ich das richtig verstanden habe, reagiert das Script nur auf Änderung des Stromes, oder? Solange der Mähroboter läuft tut sich auch beim Strom nichts. Der Ruhestrom ist 36mA

                          1 Antwort Letzte Antwort
                          0
                          • M Offline
                            M Offline
                            michihorn
                            schrieb am zuletzt editiert von
                            #13

                            Dann warte ich mal ab was passiert wenn Hans zum Laden fährt

                            paul53P 1 Antwort Letzte Antwort
                            0
                            • M michihorn

                              Dann warte ich mal ab was passiert wenn Hans zum Laden fährt

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

                              @michihorn sagte:

                              Dann warte ich mal ab was passiert

                              Das Skript oben habe ich so geändert, dass der Status auch bei Skriptstart ermittelt wird und nicht erst, wenn sich der Stromwert ändert.

                              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
                              • M Offline
                                M Offline
                                michihorn
                                schrieb am zuletzt editiert von
                                #15

                                @paul53 sagte in Gelöst: Script Fehler:

                                // Hans Status const idHans = 'hm-rpc.2.0001D8A991F432.3.STATE'; const idStrom = 'hm-rpc.2.0001D8A991F432.6.CURRENT'; const HansStatusWert = 'Haus.Hans.StatusWert'; const HansStatus = 'Haus.Hans.Status'; createState(HansStatusWert, 0, {type: 'number'}); createState(HansStatus, 'AUS', {type: 'string'}); function Hans(strom) { if (strom == 0) { setState(HansStatusWert, 0, true); setState(HansStatus, "AUS", true); log("AUS"); } if (strom >= 30 && strom <=60) { setState(HansStatusWert, 2, true); setState(HansStatus, "LÄUFT", true); log("LÄUFT"); } if (strom >= 70 && strom <= 300) { setState(HansStatusWert, 3, true); setState(HansStatus, "LÄDT", true); } if (strom >= 65 && strom <= 69) { setState(HansStatusWert, 4, true); setState(HansStatus, "Bereit", true); log("BEREIT"); } if (getState(idHans).val == false) { setState(HansStatusWert, 0, true); setState(HansStatus, "AUS", true); log("AUS"); } } on(idStrom, function(obj) { // triggert bei Wertänderung Hans(obj.state.val); }); Hans(getState(idStrom).val); // Skriptstart

                                Danke, ich verstehe aber nicht warum Deine Ergänzungen am Ende des Scriptes stehen und nicht am Anfang

                                paul53P 1 Antwort Letzte Antwort
                                0
                                • M michihorn

                                  @paul53 sagte in Gelöst: Script Fehler:

                                  // Hans Status const idHans = 'hm-rpc.2.0001D8A991F432.3.STATE'; const idStrom = 'hm-rpc.2.0001D8A991F432.6.CURRENT'; const HansStatusWert = 'Haus.Hans.StatusWert'; const HansStatus = 'Haus.Hans.Status'; createState(HansStatusWert, 0, {type: 'number'}); createState(HansStatus, 'AUS', {type: 'string'}); function Hans(strom) { if (strom == 0) { setState(HansStatusWert, 0, true); setState(HansStatus, "AUS", true); log("AUS"); } if (strom >= 30 && strom <=60) { setState(HansStatusWert, 2, true); setState(HansStatus, "LÄUFT", true); log("LÄUFT"); } if (strom >= 70 && strom <= 300) { setState(HansStatusWert, 3, true); setState(HansStatus, "LÄDT", true); } if (strom >= 65 && strom <= 69) { setState(HansStatusWert, 4, true); setState(HansStatus, "Bereit", true); log("BEREIT"); } if (getState(idHans).val == false) { setState(HansStatusWert, 0, true); setState(HansStatus, "AUS", true); log("AUS"); } } on(idStrom, function(obj) { // triggert bei Wertänderung Hans(obj.state.val); }); Hans(getState(idStrom).val); // Skriptstart

                                  Danke, ich verstehe aber nicht warum Deine Ergänzungen am Ende des Scriptes stehen und nicht am Anfang

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

                                  @michihorn sagte:

                                  ich verstehe aber nicht warum Deine Ergänzungen am Ende des Scriptes stehen und nicht am Anfang

                                  Weil man eine Funktion vor ihrem Aufruf deklarieren sollte (ein Compilerdurchlauf weniger).

                                  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

                                  M 1 Antwort Letzte Antwort
                                  0
                                  • paul53P paul53

                                    @michihorn sagte:

                                    ich verstehe aber nicht warum Deine Ergänzungen am Ende des Scriptes stehen und nicht am Anfang

                                    Weil man eine Funktion vor ihrem Aufruf deklarieren sollte (ein Compilerdurchlauf weniger).

                                    M Offline
                                    M Offline
                                    michihorn
                                    schrieb am zuletzt editiert von
                                    #17

                                    @paul53
                                    Ok vielen Dank
                                    Ich versuche gerade die Ladezeit pro Zyklus zu ermitteln. Das Programm läuft und zählt die Minuten hoch und irgendwann wird der Timer zurück gesetzt. Gibt es was einfacheres?

                                    //Ladezeit von Hans pro Zyklus
                                    createState("javascript.0.Haus.Hans.Ladezeit");
                                    const idStrom = "hm-rpc.2.0001D8A991F432.6.CURRENT";
                                    let ladezeit;
                                    const startDateTime = new Date(); 
                                    const startStamp = startDateTime.getTime();
                                    
                                    function Hans(strom) {
                                     if (strom >= 70 && strom <= 300) {
                                    let newDate = new Date();
                                        }
                                    if (strom >= 65 && strom <= 69) {
                                    let newStamp = newDate.getTime();  
                                    }
                                    };
                                    
                                    let timer;
                                    
                                    function updateClock() {
                                        newDate = new Date();
                                        newStamp = newDate.getTime();
                                        let diff = Math.round((newStamp-startStamp)/1000);
                                        
                                        let d = Math.floor(diff/(24*60*60));
                                        diff = diff-(d*24*60*60);
                                        let h = Math.floor(diff/(60*60));
                                        diff = diff-(h*60*60);
                                        let m = Math.floor(diff/(60));
                                        diff = diff-(m*60);
                                        let s = diff;
                                    ladezeit = (d+" Tage, "+h+" Stunden, "+m+" Minuten, "+s+" Sekunden");
                                        log = (d+" Tage, "+h+" Stunden, "+m+" Minuten, "+s+" Sekunden");
                                    setState('javascript.0.Haus.Hans.Ladezeit', ladezeit);
                                    }
                                    
                                    timer = setInterval(updateClock, 1000);
                                    
                                    on(idStrom, function(obj) { // triggert bei Wertänderung
                                        Hans(obj.state.val);
                                    });
                                     
                                    Hans(getState(idStrom).val); // Skriptstart 
                                    
                                    paul53P 1 Antwort Letzte Antwort
                                    0
                                    • M michihorn

                                      @paul53
                                      Ok vielen Dank
                                      Ich versuche gerade die Ladezeit pro Zyklus zu ermitteln. Das Programm läuft und zählt die Minuten hoch und irgendwann wird der Timer zurück gesetzt. Gibt es was einfacheres?

                                      //Ladezeit von Hans pro Zyklus
                                      createState("javascript.0.Haus.Hans.Ladezeit");
                                      const idStrom = "hm-rpc.2.0001D8A991F432.6.CURRENT";
                                      let ladezeit;
                                      const startDateTime = new Date(); 
                                      const startStamp = startDateTime.getTime();
                                      
                                      function Hans(strom) {
                                       if (strom >= 70 && strom <= 300) {
                                      let newDate = new Date();
                                          }
                                      if (strom >= 65 && strom <= 69) {
                                      let newStamp = newDate.getTime();  
                                      }
                                      };
                                      
                                      let timer;
                                      
                                      function updateClock() {
                                          newDate = new Date();
                                          newStamp = newDate.getTime();
                                          let diff = Math.round((newStamp-startStamp)/1000);
                                          
                                          let d = Math.floor(diff/(24*60*60));
                                          diff = diff-(d*24*60*60);
                                          let h = Math.floor(diff/(60*60));
                                          diff = diff-(h*60*60);
                                          let m = Math.floor(diff/(60));
                                          diff = diff-(m*60);
                                          let s = diff;
                                      ladezeit = (d+" Tage, "+h+" Stunden, "+m+" Minuten, "+s+" Sekunden");
                                          log = (d+" Tage, "+h+" Stunden, "+m+" Minuten, "+s+" Sekunden");
                                      setState('javascript.0.Haus.Hans.Ladezeit', ladezeit);
                                      }
                                      
                                      timer = setInterval(updateClock, 1000);
                                      
                                      on(idStrom, function(obj) { // triggert bei Wertänderung
                                          Hans(obj.state.val);
                                      });
                                       
                                      Hans(getState(idStrom).val); // Skriptstart 
                                      
                                      paul53P Offline
                                      paul53P Offline
                                      paul53
                                      schrieb am zuletzt editiert von paul53
                                      #18

                                      @michihorn sagte:

                                      die Ladezeit pro Zyklus zu ermitteln.

                                      So ermittelst Du aber nicht die Ladezeit, sondern die Zeit ab Skriptstart. Versuche es mal so:

                                      //Ladezeit von Hans pro Zyklus
                                      const idStrom = "hm-rpc.2.0001D8A991F432.6.CURRENT";
                                      const idLadezeit = "Haus.Hans.Ladezeit";
                                      
                                      createState(idLadezeit, 'init', {type: 'string'});
                                      
                                      var timer;
                                      var startStamp = Date.now();
                                      
                                      function updateClock() {
                                          let newStamp = Date.now();
                                          let diff = Math.round((newStamp - startStamp)/1000);
                                          let d = Math.floor(diff/(24*60*60));
                                          diff = diff-d*24*60*60;
                                          let h = Math.floor(diff/(60*60));
                                          diff = diff-h*60*60;
                                          let m = Math.floor(diff/(60));
                                          diff = diff-m*60;
                                          let s = diff;
                                          let ladezeit = (d+" Tage, "+h+" Stunden, "+m+" Minuten, "+s+" Sekunden");
                                          log(ladezeit);
                                          setState(idLadezeit, ladezeit, true);
                                      }
                                      
                                      function Hans(strom) {
                                          if (strom >= 70) timer = setInterval(updateClock, 1000);
                                          else if(timer) clearInterval(timer);
                                      }
                                      
                                      on(idStrom, function(obj) { // triggert bei Wertänderung
                                          if(obj.state.val >= 70 && obj.oldState.val < 70) startStamp = Date.now();
                                          Hans(obj.state.val);
                                      });
                                      
                                      Hans(getState(idStrom).val); // Skriptstart 
                                      

                                      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
                                      • M Offline
                                        M Offline
                                        michihorn
                                        schrieb am zuletzt editiert von
                                        #19

                                        Danke klappt toll :-)

                                        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

                                        705

                                        Online

                                        32.6k

                                        Benutzer

                                        82.1k

                                        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