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 sagte:

      eigenständiges Script, oder meins von oben erweitern?

      Weder noch. Die komplette Funktion cacheSelectorState.each(function(id, i) austauschen.

      Sorry für die Fragen. JS ist ein Buch mit 1000 Siegeln für mich.

      Also,

      /* Status Zahl Fenster
      Homematic var cacheSelectorLevel = $('channel[state.id=*.STATE](functions="Fenster")');
      Mi var cacheSelectorState = $('state[id=*.state](functions="Fenster")');
      {1}
      */
      var logging = false;
       
      var idAnzahlEin = 'javascript.0.Status.Fenster.Anzahl_auf',
          idAnzahl = 'javascript.0.Status.Fenster.Anzahl',
          idText = 'javascript.0.Status.Fenster.Text',
          idRaum = 'javascript.0.Status.Fenster.Raum', // <---- NEU
          idAnsage = 'javascript.0.Status.Fenster.Ansage';
      

      tauschen in

          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 deviceId = id.substring(0, id.lastIndexOf("."));
              var devicename = getObject(deviceId).common.name; 
              var raumname = getObject(id, "rooms").enumNames[0]; // <---- NEU
              if (logging) {
                  log('---Mi----');
                  log('Kanal: ' + devicename);
                  log('Status: ' + status);
              }
              if (status) { // wenn Zustand = true, dann wird die Anzahl der Fenster hochgezählt
                  ++anzahlLichterAn;
                  textLichterAn.push(devicename); // Zu Array hinzufügen
                  textRaum.push(raumname); // <---- NEU
              }
              ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
          });
      
      crunchip 1 Reply Last reply Reply Quote 0
      • crunchip
        crunchip Forum Testing Most Active @Negalein last edited by

        @Negalein @paul53 meint diesen Block austauschen
        09aca605-c468-41fe-a186-a20c4f8d8a4d-image.png

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

          Danke @paul53 und @crunchip

          Ich bin dank euch einen Schritt weiter! 🙂

          DP "Text" wird richtig ausgefüllt
          DP "Raum" erscheint weiterhin dieses [object Object]

          objects - ioBroker (11).png
          objects - ioBroker (12).png

          enums - ioBroker (2).png
          enums - ioBroker (3).png

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

            @Negalein
            Wie sieht es aus, wenn das Gewerk "Fenster" und der Raum "Schlafzimmer" nur dem Datenpunkt und nicht auch dem Kanal zugeordnet werden ?

            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
              Wie sieht es aus, wenn das Gewerk "Fenster" und der Raum "Schlafzimmer" nur dem Datenpunkt und nicht auch dem Kanal zugeordnet werden ?

              gleiches Ergebnis

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

                @Negalein probier mal einen anderen Raum, vllt findest so den Fehler, bei mir ging plötzlich der Raum Flur nicht mehr
                zur Not auch enum.funktions.fenster auch mal löschen und neu anlegen

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

                  @Negalein
                  Setze mal logging auf true und tausche die Zeile

                              log('Kanal: ' + devicename);
                  

                  gegen

                              log('Raum: ' + raumname);
                  

                  Was kommt im Log ? Version des JS-Adapters ?

                  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:

                    Was kommt im Log ? Version des JS-Adapters ?

                    JS: 4.1.14

                    Log:

                    22:23:07.022	info	javascript.0 Stop script script.js.common.Fensterzählen
                    22:23:07.187	info	javascript.0 Start javascript script.js.common.Fensterzählen
                    22:23:07.187	info	javascript.0 script.js.common.Fensterzählen: registered 2 subscriptions and 0 schedules
                    22:23:09.182	info	javascript.0 script.js.common.Fensterzählen: Auslöser Skriptstart
                    22:23:09.182	info	javascript.0 script.js.common.Fensterzählen: ++++++ Fenster Anzahl ++++
                    22:23:09.182	info	javascript.0 script.js.common.Fensterzählen: #### Mi #####
                    22:23:09.182	info	javascript.0 script.js.common.Fensterzählen: ---Mi----
                    22:23:09.182	info	javascript.0 script.js.common.Fensterzählen: Raum: [object Object]
                    22:23:09.182	info	javascript.0 script.js.common.Fensterzählen: Status: false
                    22:23:09.182	info	javascript.0 script.js.common.Fensterzählen: #### DIMMER #####
                    22:23:09.182	info	javascript.0 script.js.common.Fensterzählen: Text:
                    22:23:09.182	info	javascript.0 script.js.common.Fensterzählen: Anzahl Fenster: 1 # davon Fenster offen: 0
                    
                    paul53 2 Replies 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 probier mal einen anderen Raum, vllt findest so den Fehler, bei mir ging plötzlich der Raum Flur nicht mehr
                      zur Not auch enum.funktions.fenster auch mal löschen und neu anlegen

                      hat leider nichts gebracht

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

                        @Negalein
                        Dann versuche mal das Log so zu ändern:

                                    log('Raum: ' + JSON.stringify(raumname));
                        
                        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
                          Dann versuche mal das Log so zu ändern:

                                      log('Raum: ' + JSON.stringify(raumname));
                          

                          [object Objekt] bleibt bestehen

                          Log:

                          javascript.0	2019-07-17 22:46:30.497	info	script.js.common.Fensterzählen: Anzahl Fenster: 1 # davon Fenster offen: 0
                          javascript.0	2019-07-17 22:46:30.497	info	script.js.common.Fensterzählen: Text:
                          javascript.0	2019-07-17 22:46:30.497	info	script.js.common.Fensterzählen: #### DIMMER #####
                          javascript.0	2019-07-17 22:46:30.497	info	script.js.common.Fensterzählen: Status: false
                          javascript.0	2019-07-17 22:46:30.497	info	script.js.common.Fensterzählen: Raum: {"en":"Sleeping room","de":"Schlafzimmer","ru":"Спальня","pt":"Quarto de dormir","nl":"Slaapkamer","fr":"Chambre à coucher","it":"Camera da letto","es":"Dormitor
                          javascript.0	2019-07-17 22:46:30.497	info	script.js.common.Fensterzählen: ---Mi----
                          javascript.0	2019-07-17 22:46:30.497	info	script.js.common.Fensterzählen: #### Mi #####
                          javascript.0	2019-07-17 22:46:30.496	info	script.js.common.Fensterzählen: ++++++ Fenster Anzahl ++++
                          javascript.0	2019-07-17 22:46:30.496	info	script.js.common.Fensterzählen: Auslösender Schalter: mihome.0.devices.magnet_158d0003139ea7.state: false
                          javascript.0	2019-07-17 22:46:25.334	info	script.js.common.Fensterzählen: Anzahl Fenster: 1 # davon Fenster offen: 1
                          javascript.0	2019-07-17 22:46:25.334	info	script.js.common.Fensterzählen: Text: Schlafzimmer
                          javascript.0	2019-07-17 22:46:25.334	info	script.js.common.Fensterzählen: #### DIMMER #####
                          javascript.0	2019-07-17 22:46:25.333	info	script.js.common.Fensterzählen: Status: true
                          javascript.0	2019-07-17 22:46:25.333	info	script.js.common.Fensterzählen: Raum: {"en":"Sleeping room","de":"Schlafzimmer","ru":"Спальня","pt":"Quarto de dormir","nl":"Slaapkamer","fr":"Chambre à coucher","it":"Camera da letto","es":"Dormitor
                          javascript.0	2019-07-17 22:46:25.333	info	script.js.common.Fensterzählen: ---Mi----
                          javascript.0	2019-07-17 22:46:25.333	info	script.js.common.Fensterzählen: #### Mi #####
                          javascript.0	2019-07-17 22:46:25.333	info	script.js.common.Fensterzählen: ++++++ Fenster Anzahl ++++
                          javascript.0	2019-07-17 22:46:25.332	info	script.js.common.Fensterzählen: Auslösender Schalter: mihome.0.devices.magnet_158d0003139ea7.state: true
                          
                          paul53 2 Replies Last reply Reply Quote 0
                          • paul53
                            paul53 @Negalein last edited by

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

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

                            in

                                    var raumname = getObject(id, "rooms").enumNames.de; // <---- NEU
                            
                            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
                              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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            640
                                            Online

                                            31.7k
                                            Users

                                            79.9k
                                            Topics

                                            1.3m
                                            Posts

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