Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Wie einfache Zeitschaltung?

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.4k

Wie einfache Zeitschaltung?

Scheduled Pinned Locked Moved Skripten / Logik
34 Posts 7 Posters 9.2k Views
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • M Offline
    M Offline
    Master77
    wrote on last edited by
    #25

    Vielen Dank für die hilfreichen Tipps und die zusammengestellten Skripte. Wie gesagt, ich bin gerade erst am Anfang mit IoBroker. Habe bereits einiges hin bekommen, nur die Sache mit Blockly macht mir zu schaffen. Nachdem ich eure Zusammenstellung sehe kommt langsam Licht ins Dunkel. Werde die ganze Sache mal testen und dann wie gesagt sofort berichten. Nochmals vielen Dank…..

    Gruß Markus

    Gesendet von meinem HUAWEI NXT-L29 mit Tapatalk

    1 Reply Last reply
    0
    • N Offline
      N Offline
      noxx
      wrote on last edited by
      #26

      @paul53:

      Bessere Lösung, da hier das Senden nach einer Minute wiederholt wird, falls es nicht erfolgreich (Ack = true) war:

      var idTemp = 'rflink.0.channels.Cresta_1.TEMP';
      var idAktor = 'fritzdect.0.DECT200_087610163304.state';
      
      var minOn = false;
      var temp = getState(idTemp).val;
      var aktor = getState(idAktor).val;
      
      function Zeitschaltung() {
         var morgen = compareTime('08:00', '09:00', 'between');
         var mittag = compareTime('12:00', '17:00', 'between');
         var abend = compareTime('18:00', '20:00', 'between');
         if(morgen || (mittag && temp > 25) || abend) {
            if(!aktor) setState(idAktor, true);
         } else if(aktor && !minOn) setState(idAktor, false);
      }
      
      schedule('* * * * *', Zeitschaltung);  // jede Minute
      
      on(idTemp, function(dp) {
         temp = dp.state.val;
      });
      
      on({id: idAktor, ack: true}, function(dp) {
         aktor = dp.state.val;
         if(aktor) {
            minOn = true;
            setTimeout(function() {minOn = false;}, 1800000);  // 30 Minuten
         }
      }); 
      ```` `  
      

      Hallo,

      bin gerade zufällig zuhause und sehe das die Pumpe läuft.

      fritzdect.0	2017-07-07 13:08:02.327	info	polling! fritzdect is alive
      fritzdect.0	2017-07-07 13:06:00.916	info	Turned switch 087610163304 on
      fritzdect.0	2017-07-07 13:06:00.157	info	SWITCH ID: 087610163304 identified for command
      fritzdect.0	2017-07-07 13:03:02.314	info	polling! fritzdect is alive
      fritzdect.0	2017-07-07 13:03:00.920	info	Turned switch 087610163304 off
      fritzdect.0	2017-07-07 13:03:00.158	info	SWITCH ID: 087610163304 identified for command
      fritzdect.0	2017-07-07 13:02:00.921	info	Turned switch 087610163304 off
      fritzdect.0	2017-07-07 13:02:00.157	info	SWITCH ID: 087610163304 identified for command
      fritzdect.0	2017-07-07 13:00:01.320	info	Turned switch 087610163304 off
      fritzdect.0	2017-07-07 13:00:00.166	info	SWITCH ID: 087610163304 identified for command
      fritzdect.0	2017-07-07 12:59:00.905	info	Turned switch 087610163304 off
      fritzdect.0	2017-07-07 12:59:00.156	info	SWITCH ID: 087610163304 identified for command
      fritzdect.0	2017-07-07 12:58:02.307	info	polling! fritzdect is alive
      fritzdect.0	2017-07-07 12:58:00.912	info	Turned switch 087610163304 on
      fritzdect.0	2017-07-07 12:58:00.156	info	SWITCH ID: 087610163304 identified for command
      fritzdect.0	2017-07-07 12:57:01.332	info	Turned switch 087610163304 on
      fritzdect.0	2017-07-07 12:57:00.155	info	SWITCH ID: 087610163304 identified for command
      fritzdect.0	2017-07-07 12:56:00.925	info	Turned switch 087610163304 on
      fritzdect.0	2017-07-07 12:56:00.156	info	SWITCH ID: 087610163304 identified for command
      fritzdect.0	2017-07-07 12:55:00.915	info	Turned switch 087610163304 on
      fritzdect.0	2017-07-07 12:55:00.155	info	SWITCH ID: 087610163304 identified for command
      

      ID der Temp Sensors:

      rflink.0.channels.Cresta_1.TEMP

      Aktuell 23,2°. Normal dürfte die doch nicht angehen, oder?
      2880_1.png

      1 Reply Last reply
      0
      • paul53P Offline
        paul53P Offline
        paul53
        wrote on last edited by
        #27

        @noxx:

        Aktuell 23,2°. Normal dürfte die doch nicht angehen, oder? `
        War es vielleicht zwischen 12:45 und 13:00 mal über 25 °C und die Pumpe läuft noch aufgrund der Mindestlaufzeit ?

        Um zu sehen, was wann passiert, helfen zum Testen ein par Logs, z.B. am Ende der Funktion Zeitschaltung

            log('morgen: ' + morgen + ', mittag: ' + mittag + ', Temperatur: ' + temp + ', abend: ' + abend + ', Mindestlaufzeit: ' + minOn);
        

        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

        1 Reply Last reply
        0
        • N Offline
          N Offline
          noxx
          wrote on last edited by
          #28

          Nein, habe gerade Pumpe ausgeschaltet und nun ist die wieder

          an

          fritzdect.0	2017-07-07 14:43:02.520	info	polling! fritzdect is alive
          fritzdect.0	2017-07-07 14:40:01.339	info	Turned switch 087610163304 on
          fritzdect.0	2017-07-07 14:40:00.157	info	SWITCH ID: 087610163304 identified for command
          fritzdect.0	2017-07-07 14:38:02.509	info	polling! fritzdect is alive
          fritzdect.0	2017-07-07 14:36:00.924	info	Turned switch 087610163304 off
          fritzdect.0	2017-07-07 14:36:00.156	info	SWITCH ID: 087610163304 identified for command
          fritzdect.0	2017-07-07 14:35:00.923	info	Turned switch 087610163304 off
          fritzdect.0	2017-07-07 14:35:00.157	info	SWITCH ID: 087610163304 identified for command
          fritzdect.0	2017-07-07 14:34:01.457	info	Turned switch 087610163304 off
          fritzdect.0	2017-07-07 14:34:00.156	info	SWITCH ID: 087610163304 identified for command
          fritzdect.0	2017-07-07 14:33:02.500	info	polling! fritzdect is alive
          fritzdect.0	2017-07-07 14:32:00.935	info	Turned switch 087610163304 on
          fritzdect.0	2017-07-07 14:32:00.158	info	SWITCH ID: 087610163304 identified for command
          fritzdect.0	2017-07-07 14:31:00.954	info	Turned switch 087610163304 on
          fritzdect.0	2017-07-07 14:31:00.158	info	SWITCH ID: 087610163304 identified for command
          fritzdect.0	2017-07-07 14:30:00.933	info	Turned switch 087610163304 on
          fritzdect.0	2017-07-07 14:30:00.156	info	SWITCH ID: 087610163304 identified for command
          

          Beim LOG gibts nen Fehler

          14:45:06.350	[info]	javascript.0 Stop script script.js.common.PoolPumpe
          14:45:06.389	[info]	javascript.0 Start javascript script.js.common.PoolPumpe
          14:45:06.391	[error]	javascript.0 script.js.common.PoolPumpe: ReferenceError: morgen is not defined at script.js.common.PoolPumpe:29:18 at ContextifyScript.Script.runInContext (vm.js:35:29)
          
          var idTemp = 'rflink.0.channels.Cresta_1.TEMP';
          var idAktor = 'fritzdect.0.DECT200_087610163304.state';
          
          var minOn = false;
          var temp = getState(idTemp).val;
          var aktor = getState(idAktor).val;
          
          schedule('* * * * *', function() {  // jede Minute
             var morgen = compareTime('08:00', '09:00', 'between');
             var mittag = compareTime('12:00', '17:00', 'between');
             var abend = compareTime('18:00', '20:00', 'between');
             if(morgen || (mittag && temp > 25) || abend) {
                if(!aktor) setState(idAktor, true);
             } else if(aktor && !minOn) setState(idAktor, false);
          });
          
          on(idTemp, function(dp) {
             temp = dp.state.val;
          });
          
          on({id: idAktor, ack: true}, function(dp) {
             aktor = dp.state.val;
             if(aktor) {
                minOn = true;
                setTimeout(function() {minOn = false;}, 1800000);  // 30 Minuten
             }
          }); 
          
          log('morgen: ' + morgen + ', mittag: ' + mittag + ', Temperatur: ' + temp + ', abend: ' + abend + ', Mindestlaufzeit: ' + minOn);
          

          EDIT

          Sehe gerade, das die Temp Anzeige manchmal auf 26°C springt, warum auch immer. Na wird wohl der "Fehler" liegen. Evtl

          empfange ich auf dem selben Kanal auch einen Sensor vom Nachbarn….

          1 Reply Last reply
          0
          • paul53P Offline
            paul53P Offline
            paul53
            wrote on last edited by
            #29

            Am Ende des Skripts wird das Log nur einmal bei Skriptstart ausgeführt. Richtig:

            var idTemp = 'rflink.0.channels.Cresta_1.TEMP';
            var idAktor = 'fritzdect.0.DECT200_087610163304.state';
            
            var minOn = false;
            var temp = getState(idTemp).val;
            var aktor = getState(idAktor).val;
            
            schedule('* * * * *', function() {  // jede Minute
               var morgen = compareTime('08:00', '09:00', 'between');
               var mittag = compareTime('12:00', '17:00', 'between');
               var abend = compareTime('18:00', '20:00', 'between');
               if(morgen || (mittag && temp > 25) || abend) {
                  if(!aktor) setState(idAktor, true);
               } else if(aktor && !minOn) setState(idAktor, false);
               log('morgen: ' + morgen + ', mittag: ' + mittag + ', Temperatur: ' + temp + ', abend: ' + abend + ', Mindestlaufzeit: ' + minOn);
            });
            
            on(idTemp, function(dp) {
               temp = dp.state.val;
            });
            
            on({id: idAktor, ack: true}, function(dp) {
               aktor = dp.state.val;
               if(aktor) {
                  minOn = true;
                  setTimeout(function() {minOn = false;}, 1800000);  // 30 Minuten
               }
            });
            
            

            Dann kommt auch die Fehlermeldung nicht, denn die Variable morgen ist lokal innerhalb der Funktion.

            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
            Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

            1 Reply Last reply
            0
            • M Offline
              M Offline
              Master77
              wrote on last edited by
              #30

              Hallo zusammen. Habe am Wochenende wieder ein wenig Zeit zum bastel und ausprobieren gehabt. Das Skript von dna909 funktioniert super. Habe nur noch eine Frage dazu. Wenn ich bei laufender Zeitschaltuhr das Bauteil aus der Reihe schalte ( Zeitschaltuhr Statur Bauteil aus und ich schalte per Schalter in Vis das Bauteil an) ändert die Zeitschaltuhr das relativ schnell wieder. Kann man diese Zeitspanne nicht ein wenig verlängern? Habe schon versucht bei Blocky unter Zeitplan auf alle zwei Stunden zu ändern. Hatte gedacht das durch diese Einstellung der Status der Zeitschaltuhr alle zwei Stunden geprüft wird. Ist dem nicht so? Danke im voraus für eure Hilfe. Im Anhang nochmal das Blocky Diagramm.

              Gruß Markus

              Gesendet von meinem HUAWEI NXT-L29 mit Tapatalk
              2754_screenshot_20170710-220715.png

              1 Reply Last reply
              0
              • rantanplanR Online
                rantanplanR Online
                rantanplan
                wrote on last edited by
                #31

                @Master77:

                Hallo zusammen. Habe am Wochenende wieder ein wenig Zeit zum bastel und ausprobieren gehabt. Das Skript von dna909 funktioniert super. Habe nur noch eine Frage dazu. Wenn ich bei laufender Zeitschaltuhr das Bauteil aus der Reihe schalte ( Zeitschaltuhr Statur Bauteil aus und ich schalte per Schalter in Vis das Bauteil an) ändert die Zeitschaltuhr das relativ schnell wieder. Kann man diese Zeitspanne nicht ein wenig verlängern? Habe schon versucht bei Blocky unter Zeitplan auf alle zwei Stunden zu ändern. Hatte gedacht das durch diese Einstellung der Status der Zeitschaltuhr alle zwei Stunden geprüft wird. Ist dem nicht so? Danke im voraus für eure Hilfe. Im Anhang nochmal das Blocky Diagramm. `
                Hallo Master77

                Bilder bitte NIE als Link sondern als ".png" hier einbetten.

                Ich konnte mir Dein Bild also nicht genau anschauen.

                Bitte Deinen Beitrag editieren und Screenshot ändern.

                Grundsätzlich ist es schwierig in eine automatik manuell einzugreifen.

                Woher soll das Script den wissen, dass Du etwas manuell geändert hast?

                Das würde nur über eine zusätzliche Variable gehen.

                Grüße

                Rantanplan

                CCU3 / MS Server 2019(VM) / Scripten mit Blockly

                1 Reply Last reply
                0
                • M Offline
                  M Offline
                  Master77
                  wrote on last edited by
                  #32

                  Hallo. Habe den Beitrag nochmal editiert. Durch den Zeitplan kann man doch einen Intervall angeben in dem die Zeitschaltuhr prüft ob der Status der gegeben sein muss aus stimmt. Beispielsweise wenn ich die Pumpe manuelle um 19 Uhr nochmal anschalte die Zeitschaltuhr aber erst nach einer vorgegebenen Zeit den Status erneut prüft. Hatte gedacht das geht in dem abgebildeten Zeitplan Blocky. So hatte ich es zumindest verstanden als ich auf die *****drauf gegangen bin. Jedoch hatte die Änderung in dem Zeitplan nicht den gewünschten Erfolg gebracht.

                  Gruß Markus

                  Gesendet von meinem HUAWEI NXT-L29 mit Tapatalk

                  1 Reply Last reply
                  0
                  • rantanplanR Online
                    rantanplanR Online
                    rantanplan
                    wrote on last edited by
                    #33

                    Hallo Master77

                    So etwas passiert wenn in einem Thread unterschiedliche Probleme bearbeitet werden.

                    In der ursprünglichen Anforderung ging es um eine Pumpe die in einem bestimmten Zeitraum für eine bestimmte Dauer läuft.

                    Dein gezeigtes Beispiel hat einen Trigger, der JEDE MINUTE startet.

                    Zwischen 18 und 24 Uhr wird die Lampe eingeschaltet WENN sie AUS ist.

                    Zu jedem anderen Zeitpunkt (sonst-Teil) wird die Lampe ausgeschaltet WENN sie AN ist.

                    Wenn Du die Lampe um 10 Uhr einschaltest, wird sie SPÄTESTENS eine Minute danach wieder ausgeschaltet.

                    Was willst Du erreichen?

                    Eventuell in einem neuen Thread mit "[FRAGE] Blockly…....." im Betreff.

                    Grüße

                    Rantanplan

                    CCU3 / MS Server 2019(VM) / Scripten mit Blockly

                    1 Reply Last reply
                    0
                    • M Offline
                      M Offline
                      Master77
                      wrote on last edited by
                      #34

                      Hallo. Da es in dem ursprünglichen Beitrag ebenfalls um eine Blocky Zeitschaltuhr ging hatte ich gedacht ich klinke mich in das Thema mit ein. Wollte hier ja nicht für Unordnung sorgen. Was ich genau möchte hatte ich ja bereits geschrieben. Aus der Reihe manuell schalten und die Zeitschaltuhr soll erst nach einer Zeit x den Zustand erneut prüfen und ggf korrigieren. Nicht bereits nach 1 Minute. Werde selber noch mal versuchen die Sache auf die Kette zu bekommen. Ansonsten muss ich halt einen neuen Thread auf machen.

                      Gruß Markus

                      Gesendet von meinem HUAWEI NXT-L29 mit Tapatalk

                      1 Reply Last reply
                      0
                      Reply
                      • Reply as topic
                      Log in to reply
                      • Oldest to Newest
                      • Newest to Oldest
                      • Most Votes


                      Support us

                      ioBroker
                      Community Adapters
                      Donate

                      816

                      Online

                      32.6k

                      Users

                      82.3k

                      Topics

                      1.3m

                      Posts
                      Community
                      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                      ioBroker Community 2014-2025
                      logo
                      • Login

                      • Don't have an account? Register

                      • Login or register to search.
                      • First post
                        Last post
                      0
                      • Home
                      • Recent
                      • Tags
                      • Unread 0
                      • Categories
                      • Unreplied
                      • Popular
                      • GitHub
                      • Docu
                      • Hilfe