Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [gelöst] Skript Fenster offen mit ZWave Sensoren

    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] Skript Fenster offen mit ZWave Sensoren

    This topic has been deleted. Only users with topic management privileges can see it.
    • S
      Sunny 0 last edited by Sunny 0

      Hallo zusammen,

      ich bin auf das Skript von pix für das zählen von Fenstern gestoßen und habe versucht dieses für für unsere ZWave Fenstersensoren umzuschreiben, was leider nicht geklappt hat.

      Die Datenpunkte der Sensoren sehen wie folgt aus:
      a5ec66d7-d978-4eb2-8e0c-7fca43a03cb8-image.png

      Die Sensoren habe ich der Funktion Fenster zugefügt:
      01e1c383-7dc9-4cb3-b536-78d31115a10e-image.png

      Ich habe bei dem Namen mal das TFK versuchsweise eingefügt. Aber das Script gibt mir bei keiner Variante was aus:
      cad861ef-147d-4306-8355-7d6cfb8de261-image.png

      Kann mir jmd. ein Tipp geben, was ich alles bei dem Script ändern muss?

      Vielen Dank.

      LG Sunny

      htrecksler 1 Reply Last reply Reply Quote 0
      • htrecksler
        htrecksler Forum Testing @Sunny 0 last edited by

        @sunny-0 hast du mal den Javascript Adapter neu gestartet?

        S 1 Reply Last reply Reply Quote 0
        • S
          Sunny 0 @htrecksler last edited by

          @htrecksler
          Ja, den Adapter habe ich bereits neu gestartet. Die Fenster habe ich auch ein paar Mal geöffnet um den Status zu ändern.

          Hat aber alle nichts gebracht.

          Bei meiner Suche bin ich auch auf den Vorschlag gestoßen noch folgende Zeile zuzufügen:
          var cacheSelectorZwave = $('stateid=.on[role=sensor]');//var cacheSelectorZwave = $('channelstate.id=.ON');(functions="Fenster")');

          Hat aber auch nichts gebracht 😞 Ich vermute, dass ich noch irgendwas abgeändert werden muss, aber leider habe ich hier nicht viel Ahnung

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

            @sunny-0
            Versuche es mal mit

            const cacheSelectorZwave = $('zwave*.Sensor_1(functions=fenster)');
            
            S 1 Reply Last reply Reply Quote 0
            • S
              Sunny 0 @paul53 last edited by

              @paul53
              Ich hab das mal in Zeile 38 zugefügt und den Adapter habe ich auch nochmal neu gestertet. Leider ohne erfolg 😞

              Das fubction fenster(zustand) habe ich auch einmal mit dem Original functionfensterzustand(zustand) versucht.

              function fenster(zustand) {
              var meldung;
              switch (zustand) {
              case 1:
              meldung = 'RHS gekippt';
              break;
              case 2:
              meldung = 'RHS offen';
              break;
              case true:
              meldung = 'TFK offen';
              break;
              default:
              meldung = 'geschlossen';
              break;
              }
              return(meldung);
              }

              createState('zählen_Fenster.anzahlFenster', { // wenn benötigt: Anzahl der vorhandenen Fenster
              type: 'number',
              min: 0,
              def: 0,
              role: 'value'
              });
              createState('zählen_Fenster.anzahlFensterauf', { // Anzahl der Fenster, die auf sind als Variable unter Javascript.0 anlegen
              type: 'number',
              min: 0,
              def: 0,
              role: 'value'
              });
              createState('zählen_Fenster.textFensterauf', { // Anzahl der offenen Fenster und deren Namen als Variable unter Javascript.0 anlegen
              type: 'string',
              def: ' ',
              role: 'value'
              });

              const cacheSelectorZwave = $('zwave*.Sensor*(functions=fenster)');
              var cacheSelectorState = $('channelstate.id=*.STATE');

              function countFenster(obj) {
              // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk Fenster auf 0
              var anzahlFenster = 0;
              var anzahlFensterauf = 0;
              var textFensterauf = [];

              log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val);              // Info im Log, welcher Zustand sich geändert hat
              
              cacheSelectorState.each(function (id, i) {                                  // Schleife für jedes gefundenen Element *.STATE im Gewerk Fenster
                  var status = getState(id).val;                                          // Zustand *.STATE abfragen (jedes Element)
                  var obj    = getObject(id);
                  var name = getObject(id).common.name;
                  var devicename = name.substring(0, name.indexOf(".STATE"));             //.state aus Text entfernen
                  if (status /*TFK*/ || status === 1 || status === 2 /*RHS*/) {  // wenn Zustand offen, dann wird die Anzahl der Fenster hochgezählt
                       ++anzahlFensterauf;
                       textFensterauf.push(devicename + ' (' + fensterstatus(status) + ')');  // Name und Zustand zum Array hinzufügen
                  }
                  log('Fenster #' + (i+1) + ': ' + devicename + ' ' + fensterstatus(status)/* + ' (' + status + ' / ' + typeof status + ')'*/);
                  ++anzahlFenster;                                                        // Zählt die Anzahl der vorhandenen Fenster unabhängig vom Status
              });
              
              // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                  log("Text: " + textFensterauf);
                  log("Anzahl Fenster: " + anzahlFenster + " - davon Fenster auf: " +  anzahlFensterauf);
              
              // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
              setState("zählen_Fenster.textFensterauf", textFensterauf.join(',<br>'));    // Schreibt die aktuelle Namen der offenen Fenster
              setState("zählen_Fenster.anzahlFensterauf", textFensterauf.length);         // Schreibt die aktuelle Anzahl der offenen Fenster
              setState("zählen_Fenster.anzahlFenster", anzahlFenster);                    // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Fenster
              

              }

              cacheSelectorState.on(function(obj) { // bei Zustandänderung *. STATE im Gewerk Fenster
              countFenster(obj);
              });

              // Variable für Ansage aufbereiten
              createState('zählen_Fenster.textFensteraufAnsage', {
              type: 'string',
              def: ' ',
              role: 'value'
              });
              // Anzahl der Fenster, die auf sind, für Ansage aufbereitet
              var idQuelle = 'javascript.0.zählen_Fenster.textFensterauf',
              idAnsage = 'javascript.0.zählen_Fenster.textFensteraufAnsage';

              on(idQuelle, function (obj) {
              var text = obj.state.val;
              text = text.replace(/RHS/g, 'Drehgriff');
              text = text.replace(/TFK/g, 'Reedkontakt');
              text = (text.length > 1) ? 'Geöffnete Fenster: ' + text : 'Alle Fenster sind verschlossen';

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

                @sunny-0
                Setze bitte die Code tags richtig (um das gesamte Skript), denn so ist es nicht lesbar.

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

                  @sunny-0
                  Prüfe erst einmal in einem Test-Skript, ob der Selektor passt:

                  const idsFenster = $('zwave*.Sensor_1(functions=fenster)');
                  log('Fensteranzahl: ' + idsFenster.length);
                  idsFenster.each(function(id, i) {
                     log(getObject(id).common.name);
                  });
                  
                  S 1 Reply Last reply Reply Quote 0
                  • S
                    Sunny 0 @paul53 last edited by

                    @paul53

                    Das funktioniert:

                    29.3.2021, 14:50:13.099 [info ]: javascript.0 (4182) Stop script script.js.Test.Test

                                                          29.3.2021, 14:50:13.179	[info ]: javascript.0 (4182) Start javascript script.js.Test.Test
                                                          
                                                          29.3.2021, 14:50:13.211	[info ]: javascript.0 (4182) script.js.Test.Test: Fensteranzahl: 6
                                                          
                                                          29.3.2021, 14:50:13.212	[info ]: javascript.0 (4182) script.js.Test.Test: TFK Sensor Speisekammer
                                                          
                                                          29.3.2021, 14:50:13.213	[info ]: javascript.0 (4182) script.js.Test.Test: Sensor Essbereich TFK
                                                          
                                                          29.3.2021, 14:50:13.213	[info ]: javascript.0 (4182) script.js.Test.Test: Sensor WHZ Terrasse
                                                          
                                                          29.3.2021, 14:50:13.214	[info ]: javascript.0 (4182) script.js.Test.Test: Sensor Essbereich Terrasse
                                                          
                                                          29.3.2021, 14:50:13.214	[info ]: javascript.0 (4182) script.js.Test.Test: Sensor Wohnzimmer
                                                          
                                                          29.3.2021, 14:50:13.214	[info ]: javascript.0 (4182) script.js.Test.Test: Sensor Gästezimmer Seite
                                                          
                                                          29.3.2021, 14:50:13.215	[info ]: javascript.0 (4182) script.js.Test.Test: registered 0 subscriptions and 0 schedules
                    1 Reply Last reply Reply Quote 0
                    • S
                      Sunny 0 @paul53 last edited by

                      @paul53

                         function fenster(zustand) {
                          var meldung;
                          switch (zustand) {
                              case 1:
                                  meldung = 'RHS gekippt';
                              break;
                              case 2:
                                  meldung = 'RHS offen';
                              break;
                              case true:
                                  meldung = 'TFK offen';
                              break;
                              default:
                                  meldung = 'geschlossen';
                              break;
                          }
                          return(meldung);
                      }
                      
                      createState('zählen_Fenster.anzahlFenster', {     // wenn benötigt: Anzahl der vorhandenen Fenster
                          type: 'number',
                          min: 0,
                          def: 0,
                          role: 'value'
                      });
                      createState('zählen_Fenster.anzahlFensterauf', {  // Anzahl der Fenster, die auf sind als Variable unter Javascript.0 anlegen
                          type: 'number',
                          min: 0,
                          def: 0,
                          role: 'value'
                      });
                      createState('zählen_Fenster.textFensterauf', {      // Anzahl der offenen Fenster und deren Namen als Variable unter Javascript.0 anlegen
                          type: 'string',
                          def: ' ',
                          role: 'value'
                      });
                      
                      const cacheSelectorZwave = $('zwave*.Sensor*(functions=fenster)');
                      var cacheSelectorState  = $('channel[state.id=*.STATE](functions="Fenster")');
                      
                      function countFenster(obj) {
                           // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk Fenster auf 0
                          var anzahlFenster = 0;
                          var anzahlFensterauf = 0;
                          var textFensterauf = [];
                      
                          log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val);              // Info im Log, welcher Zustand sich geändert hat
                      
                          cacheSelectorState.each(function (id, i) {                                  // Schleife für jedes gefundenen Element *.STATE im Gewerk Fenster
                              var status = getState(id).val;                                          // Zustand *.STATE abfragen (jedes Element)
                              var obj    = getObject(id);
                              var name = getObject(id).common.name;
                              var devicename = name.substring(0, name.indexOf(".STATE"));             //.state aus Text entfernen
                              if (status /*TFK*/ || status === 1 || status === 2 /*RHS*/) {  // wenn Zustand offen, dann wird die Anzahl der Fenster hochgezählt
                                   ++anzahlFensterauf;
                                   textFensterauf.push(devicename + ' (' + fensterstatus(status) + ')');  // Name und Zustand zum Array hinzufügen
                              }
                              log('Fenster #' + (i+1) + ': ' + devicename + ' ' + fensterstatus(status)/* + ' (' + status + ' / ' + typeof status + ')'*/);
                              ++anzahlFenster;                                                        // Zählt die Anzahl der vorhandenen Fenster unabhängig vom Status
                          });
                      
                          // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                              log("Text: " + textFensterauf);
                              log("Anzahl Fenster: " + anzahlFenster + " - davon Fenster auf: " +  anzahlFensterauf);
                      
                          // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                          setState("zählen_Fenster.textFensterauf", textFensterauf.join(',<br>'));    // Schreibt die aktuelle Namen der offenen Fenster
                          setState("zählen_Fenster.anzahlFensterauf", textFensterauf.length);         // Schreibt die aktuelle Anzahl der offenen Fenster
                          setState("zählen_Fenster.anzahlFenster", anzahlFenster);                    // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Fenster
                      }
                      
                      cacheSelectorState.on(function(obj) {    // bei Zustandänderung *. STATE im Gewerk Fenster
                          countFenster(obj);
                      });
                      
                      // Variable für Ansage aufbereiten
                      createState('zählen_Fenster.textFensteraufAnsage', {
                          type: 'string',
                          def: ' ',
                          role: 'value'
                      });
                      // Anzahl der Fenster, die auf sind, für Ansage aufbereitet
                      var idQuelle = 'javascript.0.zählen_Fenster.textFensterauf',
                          idAnsage = 'javascript.0.zählen_Fenster.textFensteraufAnsage';
                      
                      on(idQuelle, function (obj) {
                          var text = obj.state.val;
                          text = text.replace(/RHS/g, 'Drehgriff');
                          text = text.replace(/TFK/g, 'Reedkontakt');
                          text = (text.length > 1) ? 'Geöffnete Fenster: ' + text : 'Alle Fenster sind verschlossen';
                          setState(idAnsage, text);
                      });
                      paul53 1 Reply Last reply Reply Quote 0
                      • paul53
                        paul53 @Sunny 0 last edited by paul53

                        @sunny-0
                        Dann versuche es mal so (ist etwas vereinfacht):

                        const idsFenster = $('zwave*.Sensor_1(functions=fenster)');
                        const idAnzahl = 'zählen_Fenster.anzahlFensterauf';
                        const idText = 'zählen_Fenster.textFensterauf';
                        
                        log('Fensteranzahl: ' + idsFenster.length);
                         
                        function countFenster() {
                            var textFensterauf = [];
                            idsFenster.each(function (id, i) {   // Schleife für jedes gefundenen Element im Gewerk Fenster
                                if(getState(id).val) {  // Zustand offen
                                     textFensterauf.push(getObject(id).common.name);  // Name zum Array hinzufügen
                                }
                            });
                         
                            // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                            setState(idText, textFensterauf.join(', '), true);    // Schreibt die aktuelle Namen der offenen Fenster
                            setState(idAnzahl, textFensterauf.length, true);      // Schreibt die aktuelle Anzahl der offenen Fenster
                        }
                         
                        countFenster(); // Script start
                        idsFenster.on(function() {    // bei Wertänderung im Gewerk Fenster
                            countFenster();
                        });
                        
                        S 2 Replies Last reply Reply Quote 0
                        • S
                          Sunny 0 @paul53 last edited by

                          @paul53
                          Danke, das werd ich heute Abend mal versuchen 🙂

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

                            @paul53
                            Jetzt hab ich doch noch eine kurze Frage. Muss ich das Skript von dir in meinem bestehenden Skript einbauen? Wenn ja wo? (bin leider absoluter Newbee)

                            Ich hab einmal versucht nur das in das Skript zu nehmen, bekomme dann aber eine Warnmeldung:
                            14704:11.514 warn javascript.0 (5384) at countFenster (script.js.Status_Offen.Fenster:16:5)
                            17:04:11.514 warn javascript.0 (5384) at script.js.Status_Offen.Fenster:20:1
                            17:04:11.516 warn javascript.0 (5384) at countFenster (script.js.Status_Offen.Fenster:17:5)
                            17:04:11.516 warn javascript.0 (5384) at script.js.Status_Offen.Fenster:20:1

                            Die Datenpunkte würden so dann ja auch nicht angesprochen werden:
                            26275d22-81d0-46c2-ae21-fd237f995894-image.png

                            Diese sollen in VIS eingebunden werden

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

                              @sunny-0 sagte: Muss ich das Skript von dir in meinem bestehenden Skript einbauen?

                              Nein: Ersetzen.

                              Der Datenpunkt "anzahlFenster" wird nicht bedient, es sei denn Du ersetzt das Log in Zeile 5 durch

                              setState('zählen_Fenster.anzahlFenster', idsFenster.length, true);
                              

                              Den Datenpunkt "javascript.0.zählen_Fenster.textFensterauf" gibt es?

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

                                @sunny-0 sagte: bekomme dann aber eine Warnmeldung:

                                Was steht im Tab "Log" noch zu diesen Warnmeldungen?
                                Logs bitte in Code tags posten!

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

                                  @paul53
                                  folgende Datenpunkte habe ich durch das bisherige Skript:
                                  5d7041b6-1c50-467c-abf6-297e90aa4013-image.png

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

                                    @sunny-0 sagte: folgende Datenpunkte habe ich durch das bisherige Skript:

                                    Dann müssten sie auch befüllt werden, es sei denn, Du hast rechts oben in den Debug-Modus geschaltet.

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

                                      @paul53
                                      Der Debug Modus ist nicht angeklickt:
                                      854823ab-6e6d-4eaf-b17b-a623ff6716b8-image.png
                                      Und in der Log zeigt er mir keine Warnung oder ähnliches an, aber die Datenpunkte werden nur angelegt aber nicht befüllt:
                                      4446a243-1cd7-4a12-a97f-7f694a520dc9-image.png

                                      Hab jetzt Zeile 5 von deinem Skript geändert und das würde jetzt schonmal gehen:
                                      73c3e468-9308-4390-98fe-7a6f42824c05-image.png

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

                                        @sunny-0 sagte: die Datenpunkte werden nur angelegt aber nicht befüllt:

                                        Sie werden befüllt! Öffne mal ein/zwei Fenster.

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

                                          @paul53
                                          Hab jetzt noch eine Zeile bei deinem Skript hinzugefügt 🙂

                                          Jetzt passt es.

                                          Vielen Dank.

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

                                            @sunny-0 sagte: Hab jetzt noch eine Zeile bei deinem Skript hinzugefügt

                                            Welche?

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            533
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

                                            3
                                            23
                                            594
                                            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