Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [gelöst] Script "Zählen von Fenstern" zeigt keine offenen Fenster an

    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 "Zählen von Fenstern" zeigt keine offenen Fenster an

    This topic has been deleted. Only users with topic management privileges can see it.
    • Negalein
      Negalein Global Moderator @paul53 last edited by

      @paul53 sagte in [gelöst] Script "Zählen von Fenstern" zeigt keine offenen Fenster an:

      @Negalein
      Interessant ! Habe ich so noch nicht beobachtet. Dann ändere mal

      Danke!
      Ich denke jetzt funktioniert es!

      objects - ioBroker (13).png

      Log:

      22:57:26.424	info	javascript.0 Stop script script.js.common.Fensterzählen
      22:57:38.435	info	javascript.0 Stop script script.js.common.Fensterzählen
      22:57:41.492	info	javascript.0 Start javascript script.js.common.Fensterzählen
      22:57:41.492	info	javascript.0 script.js.common.Fensterzählen: registered 2 subscriptions and 0 schedules
      22:57:43.487	info	javascript.0 script.js.common.Fensterzählen: Auslöser Skriptstart
      22:57:43.487	info	javascript.0 script.js.common.Fensterzählen: ++++++ Fenster Anzahl ++++
      22:57:43.487	info	javascript.0 script.js.common.Fensterzählen: #### Mi #####
      22:57:43.487	info	javascript.0 script.js.common.Fensterzählen: ---Mi----
      22:57:43.487	info	javascript.0 script.js.common.Fensterzählen: Raum: undefined
      22:57:43.487	info	javascript.0 script.js.common.Fensterzählen: Status: false
      22:57:43.487	info	javascript.0 script.js.common.Fensterzählen: #### DIMMER #####
      22:57:43.487	info	javascript.0 script.js.common.Fensterzählen: Text:
      22:57:43.487	info	javascript.0 script.js.common.Fensterzählen: Anzahl Fenster: 1 # davon Fenster offen: 0
      
      paul53 1 Reply Last reply Reply Quote 0
      • paul53
        paul53 @Negalein last edited by

        @Negalein sagte:

        Ich denke jetzt funktioniert es!

        Nein, undefined ist nicht das gewünschte Ergebnis.
        Habe es gerade bei mir getestet und es funktioniert mit

        var raumname = getObject(id, "rooms").enumNames[0];
        
        Negalein 1 Reply Last reply Reply Quote 0
        • Negalein
          Negalein Global Moderator @paul53 last edited by

          @paul53 sagte in [gelöst] Script "Zählen von Fenstern" zeigt keine offenen Fenster an:

          @Negalein sagte:

          Ich denke jetzt funktioniert es!

          Nein, undefined ist nicht das gewünschte Ergebnis.
          Habe es gerade bei mir getestet und es funktioniert mit

          var raumname = getObject(id, "rooms").enumNames[0];
          

          komisch!
          Mit diesem hat er immer das [object Object] zusätzlich gezeigt.

          crunchip 1 Reply Last reply Reply Quote 0
          • crunchip
            crunchip Forum Testing Most Active @Negalein last edited by

            @Negalein bei mir funktioniert

            var raumname = getObject(id, "rooms").enumNames[0]; // <---- NEU
            

            genauso funktioniert auch

            var raumname = getObject(id, "rooms"); // <---- NEU
            
            paul53 1 Reply Last reply Reply Quote 0
            • paul53
              paul53 @crunchip last edited by

              @crunchip sagte:

              genauso funktioniert auch

              var raumname = getObject(id, "rooms"); // <---- NEU 
              

              Dabei wird aber das komplette Objekt geliefert.

              1 Reply Last reply Reply Quote 0
              • Negalein
                Negalein Global Moderator last edited by

                @paul53 @crunchip

                Könnt ich noch irgendwelche Logs, RAWs, usw. liefern?

                1 Reply Last reply Reply Quote 0
                • crunchip
                  crunchip Forum Testing Most Active @Negalein last edited by crunchip

                  @Negalein ist mir grad aufgefallen
                  du hast enum.rooms.sleeping_room
                  das ist original schon so vorgegeben und das hat bei mir damals nicht funktioniert, daher hab ich meine Räume neu angelegt, mit deutschen Bezeichnungen
                  leg dir mal einen neuen Raum an und setzt den Sensor da rein

                  und nicht vergessen
                  Java adapter neu starten

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

                    @Negalein sagte:

                    JS: 4.1.14
                    Log:

                    Wirklich ? Ab Version 4.1.13 werden Objekte im Log komplett angezeigt ! Beispiel:

                    javascript.1 script.js.common.Test: {'_id':'meineDP.0.ch2.bett','type':'state','common':{'name':'Bett','role':'','type':'boolean','read':true,'write':true,'desc':'Manuell erzeugt','def':false},'native':{},'from':'system.adapter.admin.0','user':'system.user.admin','ts':1563397568475,'acl':{'object':1636,'state':1636,'owner':'system.user.admin','ownerGroup':'system.group.administrator'},'enumIds':['enum.rooms.sleeping_room'],'enumNames':['Schlafzimmer']}
                    

                    @crunchip
                    Wie man im Log sieht, habe ich die originale Bezeichnung beibehalten.

                    crunchip Negalein 2 Replies Last reply Reply Quote 0
                    • crunchip
                      crunchip Forum Testing Most Active @paul53 last edited by

                      @paul53 bei mir gings damals nicht, ist aber auch schon ein Jahr her

                      1 Reply Last reply Reply Quote 0
                      • Negalein
                        Negalein Global Moderator @paul53 last edited by

                        @paul53 sagte in [gelöst] Script "Zählen von Fenstern" zeigt keine offenen Fenster an:

                        @Negalein sagte:

                        JS: 4.1.14

                        Wirklich ? Ab Version 4.1.13 werden Objekte im Log komplett angezeigt ! Beispiel:

                        Ja
                        adapters - ioBroker.png

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

                          @Negalein
                          Mach mal ein Upload, denn anhand der Log-Ausgaben habe ich Zweifel, dass die Version auch aktiv ist.

                          Negalein 1 Reply Last reply Reply Quote 0
                          • Negalein
                            Negalein Global Moderator @paul53 last edited by

                            @paul53 sagte in [gelöst] Script "Zählen von Fenstern" zeigt keine offenen Fenster an:

                            @Negalein
                            Mach mal ein Upload, denn anhand der Log-Ausgaben habe ich Zweifel, dass die Version auch aktiv ist.

                            23:43:00.896	info	javascript.0 Stop script script.js.common.Fensterzählen
                            23:43:04.157	info	javascript.0 Start javascript script.js.common.Fensterzählen
                            23:43:04.157	info	javascript.0 script.js.common.Fensterzählen: registered 2 subscriptions and 0 schedules
                            23:43:06.157	info	javascript.0 script.js.common.Fensterzählen: Auslöser Skriptstart
                            23:43:06.157	info	javascript.0 script.js.common.Fensterzählen: ++++++ Fenster Anzahl ++++
                            23:43:06.157	info	javascript.0 script.js.common.Fensterzählen: #### Mi #####
                            23:43:06.157	info	javascript.0 script.js.common.Fensterzählen: ---Mi----
                            23:43:06.157	info	javascript.0 script.js.common.Fensterzählen: Raum: undefined
                            23:43:06.157	info	javascript.0 script.js.common.Fensterzählen: Status: false
                            23:43:06.157	info	javascript.0 script.js.common.Fensterzählen: #### DIMMER #####
                            23:43:06.157	info	javascript.0 script.js.common.Fensterzählen: Text:
                            23:43:06.157	info	javascript.0 script.js.common.Fensterzählen: Anzahl Fenster: 1 # davon Fenster offen: 0
                            
                            paul53 1 Reply Last reply Reply Quote 0
                            • paul53
                              paul53 @Negalein last edited by

                              @Negalein
                              Irgendetwas muss in Deinen Einstellungen anders sein, dass die Raumnamen mehrsprachig geliefert werden. Versuche es mal so:

                              var raumname = getObject(id, "rooms").enumNames[0].de;
                              
                              Negalein 1 Reply Last reply Reply Quote 0
                              • Negalein
                                Negalein Global Moderator @crunchip last edited by

                                @crunchip sagte in [gelöst] Script "Zählen von Fenstern" zeigt keine offenen Fenster an:

                                @Negalein ist mir grad aufgefallen
                                du hast enum.rooms.sleeping_room
                                das ist original schon so vorgegeben und das hat bei mir damals nicht funktioniert, daher hab ich meine Räume neu angelegt, mit deutschen Bezeichnungen
                                leg dir mal einen neuen Raum an und setzt den Sensor da rein

                                und nicht vergessen
                                Java adapter neu starten

                                Raum bleibt leer 😢

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

                                  @Negalein
                                  Was ergibt die Log-Ausgabe von ?

                                  var raumname = getObject(id, "rooms");
                                  
                                  Negalein 1 Reply Last reply Reply Quote 0
                                  • Negalein
                                    Negalein Global Moderator @paul53 last edited by

                                    @paul53 sagte in [gelöst] Script "Zählen von Fenstern" zeigt keine offenen Fenster an:

                                    @Negalein
                                    Irgendetwas muss in Deinen Einstellungen anders sein, dass die Raumnamen mehrsprachig geliefert werden. Versuche es mal so:

                                    var raumname = getObject(id, "rooms").enumNames[0].de;
                                    

                                    Raumname bleibt leer

                                    23:46:41.001	info	javascript.0 Stop script script.js.common.Fensterzählen
                                    23:46:41.172	info	javascript.0 Start javascript script.js.common.Fensterzählen
                                    23:46:41.173	info	javascript.0 script.js.common.Fensterzählen: registered 2 subscriptions and 0 schedules
                                    23:46:43.173	info	javascript.0 script.js.common.Fensterzählen: Auslöser Skriptstart
                                    23:46:43.173	info	javascript.0 script.js.common.Fensterzählen: ++++++ Fenster Anzahl ++++
                                    23:46:43.173	info	javascript.0 script.js.common.Fensterzählen: #### Mi #####
                                    23:46:43.173	info	javascript.0 script.js.common.Fensterzählen: ---Mi----
                                    23:46:43.173	info	javascript.0 script.js.common.Fensterzählen: Raum: undefined
                                    23:46:43.173	info	javascript.0 script.js.common.Fensterzählen: Status: false
                                    23:46:43.173	info	javascript.0 script.js.common.Fensterzählen: #### DIMMER #####
                                    23:46:43.173	info	javascript.0 script.js.common.Fensterzählen: Text:
                                    23:46:43.173	info	javascript.0 script.js.common.Fensterzählen: Anzahl Fenster: 1 # davon Fenster offen: 0
                                    
                                    1 Reply Last reply Reply Quote 0
                                    • Negalein
                                      Negalein Global Moderator @paul53 last edited by Negalein

                                      @paul53 sagte in [gelöst] Script "Zählen von Fenstern" zeigt keine offenen Fenster an:

                                      var raumname = getObject(id, "rooms");

                                      23:49:38.862	info	javascript.0 Stop script script.js.common.Fensterzählen
                                      23:49:39.045	info	javascript.0 Start javascript script.js.common.Fensterzählen
                                      23:49:39.046	info	javascript.0 script.js.common.Fensterzählen: registered 2 subscriptions and 0 schedules
                                      23:49:41.045	info	javascript.0 script.js.common.Fensterzählen: Auslöser Skriptstart
                                      23:49:41.045	info	javascript.0 script.js.common.Fensterzählen: ++++++ Fenster Anzahl ++++
                                      23:49:41.045	info	javascript.0 script.js.common.Fensterzählen: #### Mi #####
                                      23:49:41.045	info	javascript.0 script.js.common.Fensterzählen: ---Mi----
                                      23:49:41.045	info	javascript.0 script.js.common.Fensterzählen: Raum: {"_id":"mihome.0.devices.magnet_158d0003139ea7.state","common":{"name":"Is opened","role":"state","write":false,"read":true,"type":"boolean"},"type":"state","native":{},"from":"system.adapter.mihome.0","ts":1556916038948,"acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"},"enumIds":["enum.rooms.Eltern"],"enumNames":["Eltern"]}
                                      23:49:41.045	info	javascript.0 script.js.common.Fensterzählen: Status: false
                                      23:49:41.045	info	javascript.0 script.js.common.Fensterzählen: #### DIMMER #####
                                      23:49:41.045	info	javascript.0 script.js.common.Fensterzählen: Text:
                                      23:49:41.045	info	javascript.0 script.js.common.Fensterzählen: Anzahl Fenster: 1 # davon Fenster offen: 0
                                      

                                      wieder mit [object Object]

                                      objects - ioBroker (14).png

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

                                        @Negalein
                                        Nach diesem Log (Ist jetzt wirklich 4.1.14) muss es so funktionieren:

                                        var raumname = getObject(id, "rooms").enumNames[0];
                                        

                                        mit Raum: Eltern

                                        Negalein 1 Reply Last reply Reply Quote 0
                                        • Negalein
                                          Negalein Global Moderator @paul53 last edited by

                                          @paul53 sagte in [gelöst] Script "Zählen von Fenstern" zeigt keine offenen Fenster an:

                                          @Negalein
                                          Nach diesem Log (Ist jetzt wirklich 4.1.14) muss es so funktionieren:

                                          var raumname = getObject(id, "rooms").enumNames[0];
                                          

                                          mit Raum: Eltern

                                          Danke Danke Danke
                                          es funktioniert

                                          23:53:13.239	info	javascript.0 Stop script script.js.common.Fensterzählen
                                          23:53:13.412	info	javascript.0 Start javascript script.js.common.Fensterzählen
                                          23:53:13.413	info	javascript.0 script.js.common.Fensterzählen: registered 2 subscriptions and 0 schedules
                                          23:53:15.413	info	javascript.0 script.js.common.Fensterzählen: Auslöser Skriptstart
                                          23:53:15.413	info	javascript.0 script.js.common.Fensterzählen: ++++++ Fenster Anzahl ++++
                                          23:53:15.413	info	javascript.0 script.js.common.Fensterzählen: #### Mi #####
                                          23:53:15.413	info	javascript.0 script.js.common.Fensterzählen: ---Mi----
                                          23:53:15.413	info	javascript.0 script.js.common.Fensterzählen: Raum: "Eltern"
                                          23:53:15.413	info	javascript.0 script.js.common.Fensterzählen: Status: false
                                          23:53:15.413	info	javascript.0 script.js.common.Fensterzählen: #### DIMMER #####
                                          23:53:15.413	info	javascript.0 script.js.common.Fensterzählen: Text:
                                          23:53:15.413	info	javascript.0 script.js.common.Fensterzählen: Anzahl Fenster: 1 # davon Fenster offen: 0
                                          

                                          objects - ioBroker (15).png

                                          1 Reply Last reply Reply Quote 0
                                          • S
                                            Semenchkare last edited by Semenchkare

                                            Hallo,

                                            ich benutze seit Monaten das Fensterabfragescript aus diesem Thread (eigentlich sind es drei Scripte, eines davon Blockly). Bisher hat alles wunderbar funktioniert.
                                            Seit einigen Tagen werden mir zwar die Anzahl der geöffneten Fenster, nicht aber die Räume mit geöffneten Fenstern per Alexa angesagt. Schaue ich im Datenpunkt nach, ist da auch nichts drin...

                                            folgendes Script "Zahlfenster" sollte eigentlich die Werte in den Datenpunkt "Raum" schreiben. Ich habe diesen auch einmal gelöscht, er wird wiederhergestellt, aber es werden keine betreffenden Räume mehr ermittelt.

                                            // Status Zahl Fenster
                                            
                                            var logging = true;
                                            
                                            var idAnzahlAuf = 'javascript.0.Status.Fenster.Anzahl_auf',
                                                idAnzahl = 'javascript.0.Status.Fenster.Anzahl',
                                                idText = 'javascript.0.Status.Fenster.Text',
                                                idRaum = 'javascript.0.Status.Fenster.Raum',
                                                idAnsage = 'javascript.0.Status.Fenster.Ansage';
                                            
                                            // Ab hier nix mehr ändern
                                            createState(idAnzahl, { // wenn benötigt: Anzahl der vorhandenen Fenster
                                                type: 'number',
                                                name: 'Anzahl aller Fenster',
                                                min: 0,
                                                def: 0,
                                                role: 'value'
                                            });
                                            createState(idAnzahlAuf, { // Anzahl der Fenster, die auf sind als Variable unter Javascript.0 anlegen
                                                type: 'number',
                                                name: 'Anzahl der geoeffneten Fenster',
                                                min: 0,
                                                def: 0,
                                                role: 'value'
                                            });
                                            createState(idText, { // Anzahl der geoeffneten Fenster und deren Namen als Variable unter Javascript.0 anlegen
                                                type: 'string',
                                                name: 'geoeffnete Fenster',
                                                desc: 'Namen der geoeffneten Fenster',
                                                def: ' ',
                                                role: 'value'
                                            });
                                            createState(idAnsage, {
                                                type: 'string',
                                                name: 'geoeffnete Fenster (Ansage)',
                                                desc: 'Namen der geoeffneten Fenster (für Ansage aufbereitet)',
                                                def: ' ',
                                                role: 'value'
                                            });
                                            createState(idRaum, { // Räume, in denen Fenster geoeffnet sind
                                                type: 'string',
                                                name: 'Räume mit geoeffneten Fenster',
                                                desc: 'Namen der Räume, in denen Fenster geoeffnet sind',
                                                def: ' ',
                                                role: 'value'
                                            });
                                            
                                            var cacheSelectorState = $('channel[state.id=*.STATE](functions="Fenster")'); // Gewerk Fenster
                                            
                                            function checkDevices(obj) {
                                                // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk Fenster auf 0
                                                var anzahlFensterAuf = 0;
                                                var anzahlFenster = 0;
                                                var textFensterAuf = [];
                                                var textRaum = [];
                                                if (logging) {
                                                    log('++++++ Fenster Anzahl ++++ ');
                                                    log('#### SCHALTER ##### ');
                                                }
                                                cacheSelectorState.each(function(id, i) { // Schleife für jedes gefundenen Element *.STATE im Gewerk Fenster
                                                    var obj = getObject(id);
                                                    var name = getObject(id).common.name;
                                                    var status = getState(id).val; // Zustand *.STATE abfragen (jedes Element)
                                                    var devicename = name.substring(0, name.indexOf(".STATE")); //.state aus Text entfernen
                                                    var raumname = getObject(id, "rooms");
                                            
                                                    if (logging) {
                                                        log('-------');
                                                        log('Kanal: ' + name);
                                                        log('Status: ' + status);
                                                    }
                                                    if (status) { // wenn Zustand = true, dann wird die Anzahl der Fenster hochgezählt
                                                        ++anzahlFensterAuf;
                                                        textFensterAuf.push(devicename); // Zu Array hinzufügen
                                                        textRaum.push(raumname.enumNames); //
                                                    }
                                                    ++anzahlFenster; // Zählt die Anzahl der vorhandenen Fenster unabhängig vom Status
                                                    });
                                             
                                            textRaum = deleteDuplicates(textRaum); 
                                              
                                                // Array mit Fensternamen sortieren
                                                textFensterAuf.sort();
                                                textRaum.sort();
                                                // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon auf) ausgegeben
                                                if (logging) log("Text: " + textFensterAuf);
                                                if (logging) 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(idText, textFensterAuf.join(', und ')); // Schreibt die aktuelle Namen der geoeffneten Fenster
                                                setState(idAnzahlAuf, textFensterAuf.length); // Schreibt die aktuelle Anzahl der geoeffneten Fenster
                                                setState(idAnzahl, anzahlFenster); // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Fenster
                                                // setState(idRaum, textRaum.join(',<br>')); // Räume, in denen Fenster geoeffnet sind
                                                setState(idRaum, textRaum.join(', und ')); // Räume, in denen Fenster geoeffnet sind
                                            }
                                            
                                            // Trigger
                                            cacheSelectorState.on(function(obj) { // bei Zustandänderung *.STATE im Gewerk Fenster
                                                if (logging) log('Auslösender Schalter: ' + obj.id + ': ' + obj.state.val); // Info im Log, welcher Zustand sich geändert hat
                                                checkDevices();
                                            });
                                            
                                            function main() {
                                                setTimeout(function() {
                                                    if (logging) log('Auslöser Skriptstart');
                                                    checkDevices();
                                                }, 2000);
                                            }
                                            
                                            main(); // Skriptstart-Auslöser
                                            
                                            // Aufbereitung für Ansage
                                            function strip_tags(data) {
                                                var rueckgabe = data.replace(/(&nbsp;|<([^>]+)>)/ig, " ");
                                                return (rueckgabe);
                                            }
                                            
                                            on(idText, function(obj) {
                                                var text = obj.state.val;
                                                text = (getState(idAnzahl).val > 0) ? '' + strip_tags(text) : 'Alle Fenster sind geschlossen';
                                                setState(idAnsage, text);
                                            });
                                            

                                            datenpunkt.JPG

                                            Ich habe an der Hardware nichts geändert, lediglich beim Homematic die neueste Software und beim iobroker die aktuellen Adapter bzw. den neuesten Controller 2.0.029 installiert. Script Engine ist auf 4.30, wobei ich da mal diverse niedrigere Versionen installiert habe um einen Fehler an den neueren Versionen der Engine auszuschließen....
                                            Seit Controller 2.x - aktuell bin ich auf auf 2.0.29 - funktioniert das nicht mehr.

                                            Zusammengefasst: das bisher funktionierende Script kann die Räume nicht mehr ermitteln und schreibt nichts in den Datenpunkt.
                                            Wie komme ich dem Fehler auf die Schliche?
                                            -Kann es etwas mit dem Controller zu tun haben(Version)?
                                            -Kann es evtl. mit der Raspberrymatic-Version von Homematic 3.47.18.20190918 zu tun haben?
                                            -Ich benutze node/nodejs 12.10.0 und npm 6.11.3 - beides bisher problemlos.

                                            Hat jemand eine Idee?

                                            LG Sami

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            465
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

                                            23
                                            132
                                            14032
                                            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