Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. Gelöst: Script Fehler

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Gelöst: Script Fehler

    This topic has been deleted. Only users with topic management privileges can see it.
    • M
      michihorn last edited by

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

      paul53 M 2 Replies Last reply Reply Quote 0
      • paul53
        paul53 @michihorn last edited by

        @michihorn sagte:

        der Ruhestrom ist aktuell 36mA

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

        1 Reply Last reply Reply Quote 0
        • M
          michihorn @michihorn last edited by

          @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 Reply Last reply Reply Quote 0
          • M
            michihorn last edited by

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

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

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

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

                @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

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

                  @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 1 Reply Last reply Reply Quote 0
                  • M
                    michihorn @paul53 last edited by

                    @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 
                    
                    paul53 1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 @michihorn last edited by paul53

                      @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 
                      
                      1 Reply Last reply Reply Quote 0
                      • M
                        michihorn last edited by

                        Danke klappt toll 🙂

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

                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        889
                        Online

                        31.8k
                        Users

                        80.0k
                        Topics

                        1.3m
                        Posts

                        javascript
                        2
                        19
                        554
                        Loading More Posts
                        • Oldest to Newest
                        • Newest to Oldest
                        • Most Votes
                        Reply
                        • Reply as topic
                        Log in to reply
                        Community
                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                        The ioBroker Community 2014-2023
                        logo