Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. Variable in Scheduler nutzen

    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

    SOLVED Variable in Scheduler nutzen

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

      @paul53
      Weil ich es übersehen habe 🙂
      So klappt es nun: !!!!

      const idWeckzeit = 'broadlink2.0.RM:10-0-1-9.L.Zeit_Rollo';  // Weckzeit als String "hh:mm"
      const idWecker = 'sonoff.0.Sonoff2.POWER1'; //  boolean
      
      var t = getState(idWeckzeit).val.split(':');
      var timer = schedule(t[1] + ' ' + t[0] + ' * * *', function() {
         setState(idWecker, true);
         setStateDelayed(idWecker, false, 1000, false);
      });
      
      on(idWeckzeit, function(dp) {
         t = dp.state.val.split(':');
         clearSchedule(timer);
         timer = schedule(t[1] + ' ' + t[0] + ' * * *', function() {
             setState(idWecker, true);
             setStateDelayed(idWecker, false, 1000, false);
         });
      });
      

      Nun brauche ich nur noch ein Script für Werktags und eines fürs WE.
      Dürft ich dich nochmal bitten? 🙂

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

        @dfz sagte:

        Script für Werktags und eines fürs WE.

        const idWeckzeit = 'broadlink2.0.RM:10-0-1-9.L.Zeit_Rollo';  // Weckzeit als String "hh:mm"
        const idWeckzeitWE = 'broadlink2.0.RM:10-0-1-9.L.Zeit_RolloWE';  // Weckzeit WE als String "hh:mm"
        const idWecker = 'sonoff.0.Sonoff2.POWER1'; //  boolean
         
        function rollo() {
           setState(idWecker, true);
           setStateDelayed(idWecker, false, 1000, false);
        }
        
        var t = getState(idWeckzeit).val.split(':');
        var timer1 = schedule(t[1] + ' ' + t[0] + ' * * 1-5', rollo);
        t  = getState(idWeckzeitWE).val.split(':');
        var timer2 = schedule(t[1] + ' ' + t[0] + ' * * 6,7', rollo);
        
        on(idWeckzeit, function(dp) {
           t = dp.state.val.split(':');
           clearSchedule(timer1);
           timer1 = schedule(t[1] + ' ' + t[0] + ' * * 1-5', rollo);
        });
        
        on(idWeckzeitWE, function(dp) {
           t = dp.state.val.split(':');
           clearSchedule(timer2);
           timer2 = schedule(t[1] + ' ' + t[0] + ' * * 6,7', rollo);
        });
        
        1 Reply Last reply Reply Quote 0
        • D
          dfz last edited by

          @paul53
          Vielen Dank, passt perfekt!!!!

          1 Reply Last reply Reply Quote 0
          • Jey Cee
            Jey Cee Developer last edited by

            Wenn ein Thema gelöst wurde bitte den Beitrag der die Lösung beinhaltet als gelöst Markieren. ->Anleitung

            1 Reply Last reply Reply Quote 0
            • padrino
              padrino Most Active last edited by

              Hi,

              ich würde gerne einem "schedule" einen "cron Ausdruck"(?) übergeben.
              Da ich mich nur mt Blockly auskenne, besteht mein wissen über JS nur darin mir ein Blockly als Javascript anzeigen zu lassen. 😇

              Aus diesem Blockly
              zeitplan.PNG

              habe ich mir da was zusammen gereimt... 😌

              Aber beide meiner Ansätze funktionieren nicht. 😞
              Kann mir jemand sagen, wieso, bzw. kann es sein, dass es (so) gar nicht gehen kann. 🤔

              Meine Versuche, das in ein Blockly mit Funktion zu packen:

              v1.PNG

              var k;
              
              function etwas_tun(k) {
                  schedule("k", function () {
                    console.error('test');
                  });
              }
              
              etwas_tun('51 19 * * *');
              

              v2.PNG

              var k;
              
              function etwas_tun(k) {
                  schedule(k, function () {
                    console.error('test');
                  });
              }
              
              etwas_tun('"51 19 * * *"');
              

              Der Unterschied liegt in den gesetzten Anführungszeichen, einmal in der Variablen, einmal im Funktionsaufruf.

              Ich weiß, eine gültige Funktion (ohne Nutzung der Variablen) sollte so aussehen:

              function etwas_tun(k) {
                  schedule("51 19 * * *", function () {
                    console.error('test');
                  });
              
              paul53 1 Reply Last reply Reply Quote 0
              • paul53
                paul53 @padrino last edited by paul53

                @padrino
                Wozu eine Javascript-Funktion ? Blockly bietet auch diese Version des Zeitplans:

                Blockly_temp.JPG

                Es können auch variable Werte übergeben werden.

                padrino 2 Replies Last reply Reply Quote 1
                • padrino
                  padrino Most Active @paul53 last edited by

                  @paul53
                  Wieder mit Blindheit geschlagen. 😞
                  Danke!

                  1 Reply Last reply Reply Quote 0
                  • padrino
                    padrino Most Active @paul53 last edited by

                    @paul53

                    Sorry, so ganz blick ich es dann doch nicht. 😞
                    Das ist dann ja ein Trigger und daran kann ich ja keine Änderungen mehr zur Laufzeit machen.
                    Eine Möglichkeit, die ich sehen würde, wäre das Skript immer bei Bedarf zu starten, sodass dann aktuelle Werte aus Datenpunkten gelesen und als "cron string" verwendet werden?
                    Das scheint mir aber nicht sehr sauber oder gewollt. 😌

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

                      @padrino sagte:

                      daran kann ich ja keine Änderungen mehr zur Laufzeit machen.

                      Änderungen zur Laufzeit durch Änderung der Uhrzeit in einem Datenpunkt geht z.B. so:

                      Blockly_temp.JPG

                      1 Reply Last reply Reply Quote 1
                      • padrino
                        padrino Most Active last edited by

                        Danke!
                        Das ist echt clever.
                        Verstehen tu ich's problemlos, aber auf sowas wäre ich im Leben nicht selbst gekommen. 😞

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

                          @paul53
                          Hallo, gibt es eine effizientere Lösung falls man mehrere Variablen für idWeckzeit braucht als nur eine oder zwei?
                          LG Matthias

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

                            @matthias_ effizienter als je einen shedule für jeden Timer ? Nein.

                            A.

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

                              @asgothian said in Variable in Scheduler nutzen:

                              effizienter als je einen shedule für jeden Timer ? Nein.

                              ok, danke trotzdem
                              dachte man kann vielleicht mit mehren Arrays arbeiten...

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

                                @matthias_ sagte: dachte man kann vielleicht mit mehren Arrays arbeiten...

                                Ja, aber nicht mit Blockly.

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

                                  @paul53 @paul53 Sorry hab's nicht dazugeschrieben...
                                  Ich Programmiere mit JS (bin aber noch ein Anfänger)

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

                                    @matthias_

                                    Da gibt es einen einfachen trick. Durch das Nutzen der ID deines Einstell-states als Key in einem "key/value store" kannst du die einzelnen Shedules sauber behalten. Das einzige was du machen musst um einen weiteren Alarm hinzu zu fügen ist im on einen weiteren state mit anzugeben und in der Funktion TriggerAlertFor die Aktion die für diesen State geplant ist zu definieren.

                                    Dann brauchst du nicht mehrere Arrays.

                                    let schedules = {};
                                    
                                    function TriggerAlertFor(string id)
                                    {
                                      // hier musst du die jeweilige Aktion für das aktivieren des alarms auswählen - basiert auf dem übergebenen String.
                                      //Der String der hier ankommt ist immer die ID des State mit dem du die Zeit für den Alarm festlest.
                                    }
                                    
                                    on({id:"first_timer_dp", "second_timer_dp"}, change:'ne'}, function (obj) {
                                      const alert = obj._id;
                                      if (schedules[alert]) clearShedule(schedules[alert]);
                                      const times = obj.state.val.split(':');
                                      if times.length < 2 return;
                                      schedules[obj._id] = schedule('* * '+times[0] + ' ' + times[1],function() { TriggerAlertFor(alert)}); 
                                    });
                                    
                                    Matthias_ 1 Reply Last reply Reply Quote 1
                                    • Matthias_
                                      Matthias_ @Asgothian last edited by Matthias_

                                      @asgothian Danke Vielmals 😊
                                      Wäre nicht drauf gekommen, dass man das so einfach lösen kann ... Danke😁

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

                                      Support us

                                      ioBroker
                                      Community Adapters
                                      Donate

                                      949
                                      Online

                                      31.8k
                                      Users

                                      80.0k
                                      Topics

                                      1.3m
                                      Posts

                                      6
                                      21
                                      2066
                                      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