Skip to content
  • 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
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. [gelöst]Fehler bei subscribe(channel:"…

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.0k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.8k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.0k

[gelöst]Fehler bei subscribe(channel:"…

[gelöst]Fehler bei subscribe(channel:"…

Scheduled Pinned Locked Moved Skripten / Logik
106 Posts 22 Posters 19.8k Views 1 Watching
  • 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.
  • ThisoftT Offline
    ThisoftT Offline
    Thisoft
    wrote on last edited by
    #1

    Ich habe hier ein seltsames Verhalten wenn ich per subscribe eine Aufzählung "überwachen" möchte.

    Folgendes Script:

    subscribe({channel:"fenster", change:"ne"}, function (obj) {
        var Fenster = parseInt(obj.newState.val);
        if (Fenster > 0){
        log(obj.id + " geöffnet" + new Date());
        }
        else
        log(obj.id + " geschlossen" + new Date());
    });
    

    Das Script läuft auch wie erwartet los. Allerdings beschränkt es sich bei den zu überwachenden Objekten nicht auf die in der Enum "fenster" enthaltenen sondern erfasst auch die Systemobjekte wie man im folgenden Log sieht.

    javascript-0	2015-03-08 23:12:49	info	script.js.FensterOffen1: system.adapter.admin.0.uptime geöffnetSun Mar 08 2015 23:12:49 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:49	info	script.js.FensterOffen1: system.adapter.admin.0.memHeapUsed geöffnetSun Mar 08 2015 23:12:49 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:49	info	script.js.FensterOffen1: system.adapter.admin.0.memRss geöffnetSun Mar 08 2015 23:12:49 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:48	info	script.js.FensterOffen1: system.adapter.web.0.uptime geöffnetSun Mar 08 2015 23:12:48 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:48	info	script.js.FensterOffen1: system.adapter.web.0.memHeapUsed geöffnetSun Mar 08 2015 23:12:48 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:48	info	script.js.FensterOffen1: system.adapter.web.0.memRss geöffnetSun Mar 08 2015 23:12:48 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:48	info	script.js.FensterOffen1: system.adapter.socketio.0.uptime geöffnetSun Mar 08 2015 23:12:48 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:48	info	script.js.FensterOffen1: system.adapter.socketio.0.memHeapUsed geöffnetSun Mar 08 2015 23:12:48 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:48	info	script.js.FensterOffen1: system.adapter.socketio.0.memRss geöffnetSun Mar 08 2015 23:12:48 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:44	info	script.js.FensterOffen1: system.adapter.ping.0.uptime geöffnetSun Mar 08 2015 23:12:44 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:44	info	script.js.FensterOffen1: system.adapter.ping.0.memHeapUsed geöffnetSun Mar 08 2015 23:12:44 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:44	info	script.js.FensterOffen1: system.adapter.history.0.uptime geöffnetSun Mar 08 2015 23:12:44 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:44	info	script.js.FensterOffen1: system.adapter.history.0.memHeapUsed geöffnetSun Mar 08 2015 23:12:44 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:44	info	script.js.FensterOffen1: system.adapter.history.0.memRss geöffnetSun Mar 08 2015 23:12:44 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:43	info	script.js.FensterOffen1: system.host.acer-Server.uptime geöffnetSun Mar 08 2015 23:12:43 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:43	info	script.js.FensterOffen1: system.host.acer-Server.memHeapUsed geöffnetSun Mar 08 2015 23:12:43 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:43	info	script.js.FensterOffen1: system.host.acer-Server.memRss geöffnetSun Mar 08 2015 23:12:43 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:43	info	script.js.FensterOffen1: system.adapter.hm-rpc.0.uptime geöffnetSun Mar 08 2015 23:12:43 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:43	info	script.js.FensterOffen1: system.adapter.hm-rpc.0.memHeapUsed geöffnetSun Mar 08 2015 23:12:43 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:43	info	script.js.FensterOffen1: system.adapter.hm-rpc.0.memRss geöffnetSun Mar 08 2015 23:12:43 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:40	info	script.js.FensterOffen1: system.adapter.sayit.0.uptime geöffnetSun Mar 08 2015 23:12:40 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:40	info	script.js.FensterOffen1: system.adapter.sayit.0.memHeapUsed geöffnetSun Mar 08 2015 23:12:40 GMT+0100 (Mitteleuropäische Zeit)
    javascript-0	2015-03-08 23:12:36	info	script.js.FensterOffen1: registered 1 subscription and 0 schedules
    javascript-0	2015-03-08 23:12:36	info	Start javascript script.js.FensterOffen1
    

    Mache ich was falsch oder ist das ein Fehler?

    22 HM-Geräte; PivCCU2 auf RasPi

    ioBroker-Multihost; Ubuntu-Master auf Intel-Atom und 3 RasPi-Clients

    1 Reply Last reply
    0
    • ThisoftT Offline
      ThisoftT Offline
      Thisoft
      wrote on last edited by
      #2

      So, habe mich etwas weiter durch diverse Wikis und Beiträge gekämpft 😉 Bin jetzt mit dieser Zeile

      $('channel[state.id=*.STATE](rooms=fenster').on(function (obj) {
      

      im Script auch schon ein gutes Stück weiter an meinem Ziel. Allerdings ist das (rooms=fenster) wirkungslos - habe auch schon verschiedene andere Varianten probiert aber komme nicht dahinter wie es richtig ist. Kann mir jemand sagen, was ich richtig schreiben muss wenn meine Aufzählung so angelegt ist und ich auf alle in "fenster" enthaltenen devices zugreifen möchte?

      250_enums.jpg

      Vielen Dank

      22 HM-Geräte; PivCCU2 auf RasPi

      ioBroker-Multihost; Ubuntu-Master auf Intel-Atom und 3 RasPi-Clients

      1 Reply Last reply
      0
      • BluefoxB Offline
        BluefoxB Offline
        Bluefox
        wrote on last edited by
        #3

        @Thisoft:

        So, habe mich etwas weiter durch diverse Wikis und Beiträge gekämpft 😉 Bin jetzt mit dieser Zeile

        $('channel[state.id=*.STATE](rooms=fenster').on(function (obj) {
        

        im Script auch schon ein gutes Stück weiter an meinem Ziel. Allerdings ist das (rooms=fenster) wirkungslos - habe auch schon verschiedene andere Varianten probiert aber komme nicht dahinter wie es richtig ist. Kann mir jemand sagen, was ich richtig schreiben muss wenn meine Aufzählung so angelegt ist und ich auf alle in "fenster" enthaltenen devices zugreifen möchte?

        filename="enums.jpg" index="0">~~

        Vielen Dank `
        Fast richtig:

        $('channel[state.id=*.STATE](functions=fenster').on(function (obj) {
        

        Mann muss doku erweitern. Habe selbst 5 min gesucht. 😄

        1 Reply Last reply
        0
        • ThisoftT Offline
          ThisoftT Offline
          Thisoft
          wrote on last edited by
          #4

          Hallo Bluefox,

          vielen Dank für Deine Suche 🙂

          Eine Anmerkung hätte ich noch. Wenn man in "('channel…') nur ungültige Kriterien (wie z.B. nur rooms=fenster allein) angibt dann werden alle Systemobjekte ausgewählt (s. Anfangspost).

          Ist das so gewollt? Oder solltest Du da vielleicht noch was ändern dass in dem Falle lieber gar nichts ausgewählt wird?

          Danke und Gruß

          Thilo

          22 HM-Geräte; PivCCU2 auf RasPi

          ioBroker-Multihost; Ubuntu-Master auf Intel-Atom und 3 RasPi-Clients

          1 Reply Last reply
          0
          • BluefoxB Offline
            BluefoxB Offline
            Bluefox
            wrote on last edited by
            #5

            @Thisoft:

            Hallo Bluefox,

            vielen Dank für Deine Suche 🙂

            Eine Anmerkung hätte ich noch. Wenn man in "('channel…') nur ungültige Kriterien (wie z.B. nur rooms=fenster allein) angibt dann werden alle Systemobjekte ausgewählt (s. Anfangspost).

            Ist das so gewollt? Oder solltest Du da vielleicht noch was ändern dass in dem Falle lieber gar nichts ausgewählt wird?

            Danke und Gruß

            Thilo `
            Kannst du das als Fehler hier http://forum.iobroker.org/viewforum.php?f=22 aufmachen?

            1 Reply Last reply
            0
            • ruhr70R Offline
              ruhr70R Offline
              ruhr70
              wrote on last edited by
              #6

              Hi,

              ich habe hierzu eine Frage. Meine Fähigkeiten bei JavaScript beschränken sich auf das "leihen" von Code und die Kombination daraus.

              Das Beispiel oben finde ich sehr interessant, da man darauf aufsetzend noch einiges realisieren kann.

              Z.B. alle Lampen eingeschalteten Lampen zählen, sobald in der Aufzählung Lichter ein Gerät seinen Zustand gewechselt hat (um nicht ständig zu zählen).

              Leider habe ich das Beispiel oben anscheinend noch nicht ganz verstanden.

              Meine Modifikation soll bei Änderung in der Funktion Licht (bei mir: enum.functions.Licht) reagieren.

              Bei meinen Test wurde aber auch z.B. auf Fensterkontakte reagiert und deren Zustand ausgegeben.

              $('channel[state.id=*.STATE](functions=Licht').on(function (obj) {
              //    var Licht = parseInt(obj.newState.val);
              //   if (Licht >0){
                  if (obj.newState.val === true){
                  log(obj.id + " ### an ### " + new Date());
                  }
                  else
                  log(obj.id + " ### aus ###" + new Date());
              });
              

              Dann musste ich noch folgende Zeilen rausnehmen, da dann immer der else Zweig gegriffen hatte (Die Variable Licht stand auf "NaN").

              //    var Licht = parseInt(obj.newState.val);
              //   if (Licht >0){
              
              

              Unter Aufzählungen gibt es bei mir enum.functions.Licht

              Daher dachte ich,dass die erste Zeile nur auf Objekte aus diesem Bereich reagiert.

              Den Part parseInt(obj.newState.val habe ich so verstanden, dass der boolsche Zustand true in 1 (Integer) gewandelt wird.

              Bei mir war das Ergebnis aber NaN.

              Vielleicht kann da jemand für Sorgen, dass bei mir ein Licht angehet 😉

              Adapter: Fritzbox, Unify Circuit
              Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

              1 Reply Last reply
              0
              • F Offline
                F Offline
                Fugazzy
                wrote on last edited by
                #7

                Hallo,

                bist du damit weiter gekommen?

                ich suche auch gerade ein Skript, welches mir alle eingeschalteten Lichter zählt für Schalter und Dimmer,also STATE und LEVEL.

                Ich habe mich bis hier durchgewühlt, komme aber nicht weiter

                1 Reply Last reply
                0
                • ruhr70R Offline
                  ruhr70R Offline
                  ruhr70
                  wrote on last edited by
                  #8
                  createState('anzahlLichterAn', 0);
                  
                  var anzahlLichterAn = 0;
                  var anzahlLichter = 0;
                  
                  $('channel[state.id=*.STATE](functions=Licht)').each(function (id, i) {
                      var status = getState(id).val;
                      if (status === true) {++anzahlLichterAn} 
                      log("Licht Nr. " + i + ": " + id + ": " + status);
                      ++anzahlLichter;
                  }); 
                  
                  log("Anzahl Lichter: " + anzahlLichter + " # davon an: " + anzahlLichterAn)
                  
                  setState("anzahlLichter",anzahlLichter);
                  
                  

                  Das habe ich mal gebastelt, nachdem ich die Javascript Doku von ioBroker gelesen habe.

                  https://github.com/iobroker/ioBroker.ja … /README.md

                  Dort:

                  $ - Selector

                  $(selector).on(function(obj) {});
                  $(selector).each(function(id, i) {});
                  $(selector).setState(value, ack);
                  $(selector).getState();
                  

                  Wenn man das Script startet, werden alle Komponenten im Gewerk Licht gezählt. im Log einzeln mit Zustand ausgegeben und die Summe in die Variable javascript.0.anzahlLichterAn geschrieben.

                  javascript-0	2015-05-17 17:23:57	info	script.js.Zählen: Anzahl Lichter: 8 # davon an: 5
                  javascript-0	2015-05-17 17:23:57	info	script.js.Zählen: Licht Nr. 7: hm-rpc.0.GEQ0145764.2.STATE: false
                  javascript-0	2015-05-17 17:23:57	info	script.js.Zählen: Licht Nr. 6: hm-rpc.0.GEQ0145764.1.STATE: true
                  javascript-0	2015-05-17 17:23:57	info	script.js.Zählen: Licht Nr. 5: hm-rpc.0.GEQ0145484.1.STATE: true
                  javascript-0	2015-05-17 17:23:57	info	script.js.Zählen: Licht Nr. 4: hm-rpc.0.GEQ0067058.1.STATE: true
                  javascript-0	2015-05-17 17:23:57	info	script.js.Zählen: Licht Nr. 3: hm-rpc.0.GEQ0068946.1.STATE: true
                  javascript-0	2015-05-17 17:23:57	info	script.js.Zählen: Licht Nr. 2: hm-rpc.0.FEQ0091718.1.STATE: false
                  javascript-0	2015-05-17 17:23:57	info	script.js.Zählen: Licht Nr. 1: hm-rpc.0.FEQ0073867.2.STATE: false
                  javascript-0	2015-05-17 17:23:57	info	script.js.Zählen: Licht Nr. 0: hm-rpc.0.FEQ0073867.1.STATE: true
                  javascript-0	2015-05-17 17:23:57	info	Start javascript script.js.Zählen
                  
                  

                  javascript-0 2015-05-17 17:23:57 info script.js.Zählen: Anzahl Lichter: 8 # davon an: 5

                  Mir fehlt nur die Kleinigkeit… zu verstehen, was Selektoren sind und wie ich das Script aufrufe, ohne es über das Webinterface zu starten 😉

                  Ziel: Bei Änderung eines der Lichter soll neu gezählt werden.

                  .

                  Adapter: Fritzbox, Unify Circuit
                  Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                  1 Reply Last reply
                  0
                  • BluefoxB Offline
                    BluefoxB Offline
                    Bluefox
                    wrote on last edited by
                    #9

                    > Mir fehlt nur die Kleinigkeit… zu verstehen, was Selektoren sind und wie ich das Script aufrufe, ohne es über das Webinterface zu starten ;-)

                    var cacheSelector = $('channel[state.id=*.STATE](functions=Licht)');
                    
                    cacheSelector.on(function(obj) {
                        log('New state of ' + obj.id + ': ' + obj.newState.val);
                    
                        cacheSelector.each(function (id, i) {
                            var status = getState(id).val;
                            if (status === true) {++anzahlLichterAn} 
                            log("Licht Nr. " + i + ": " + id + ": " + status);
                            ++anzahlLichter;
                        }); 
                    
                        log("Anzahl Lichter: " + anzahlLichter + " # davon an: " + anzahlLichterAn)
                    
                        setState("anzahlLichter",anzahlLichter);
                    });
                    
                    1 Reply Last reply
                    0
                    • ruhr70R Offline
                      ruhr70R Offline
                      ruhr70
                      wrote on last edited by
                      #10

                      .

                      Danke Bluefox!

                      Ich muss mir das Thema Selektoren doch mal näher ansehen 😉

                      Nun kann ich das Script endlich produktiv nutzen.

                      Ich habe noch einen Fehler von mir entfernt und die einzelnen Befehle kommentiert:

                      Die Variablen werden nun in einer Baumstruktur angelegt (javascript.0.zählen.xxx)

                      Das wollte ich nun für alle Scripte einführen, die bei mir produktiv sind.

                      createState('zählen.anzahlLichter', 0);    // wenn benötigt: Anzahl der vorhandenen Lichter
                      createState('zählen.anzahlLichterAn', 0);  // Anzahl der Lichter, die an sind als Variable unter Javascript.0 anlegen
                      
                      var cacheSelector = $('channel[state.id=*.STATE](functions=Licht)');
                      
                      cacheSelector.on(function(obj) {    // bei Zustandänderung *. STATE im Gewerk Licht
                      
                           // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk Licht auf 0
                          var anzahlLichterAn = 0;
                          var anzahlLichter = 0;
                      
                          log('New state of ' + obj.id + ': ' + obj.newState.val);    // Info im Log, welcher Zustand sich geändert hat
                      
                          cacheSelector.each(function (id, i) {                       // Schleife für jedes gefundenen Element *.STATE im Gewerk Licht
                              var status = getState(id).val;                          // Zustand *.STATE abfragen (jedes Element)
                              if (status === true) {++anzahlLichterAn}                // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                      //        log("Licht Nr. " + i + ": " + id + ": " + status);    // gibt alle Elemente *.STATE im Gewerk Licht mit dem aktuelle Status im Log aus
                              ++anzahlLichter;                                        // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                          }); 
                      
                          // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                      
                          log("Anzahl Lichter: " + anzahlLichter + " # davon an: " + anzahlLichterAn);
                      
                          // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                          setState("zählen.anzahlLichter",anzahlLichter);        // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Licht
                          setState("zählen.anzahlLichterAn",anzahlLichterAn);    // Schreibt die aktuelle Anzahl der eingeschalteten Lichter
                      });
                      
                      

                      Danke!

                      Adapter: Fritzbox, Unify Circuit
                      Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                      1 Reply Last reply
                      0
                      • F Offline
                        F Offline
                        Fugazzy
                        wrote on last edited by
                        #11

                        Super, danke,

                        ich habe die Initialisierung der Variablen mit in die Funktion genommen, da sonst der Zähler nicht zurück gesetzt wird und immer weiter zählt.

                        richtig?

                        Wie bekomme ich da nun noch die LEVEL der Dimmer mit hinein? (die haben ja keinen STATE)

                        1 Reply Last reply
                        0
                        • ruhr70R Offline
                          ruhr70R Offline
                          ruhr70
                          wrote on last edited by
                          #12

                          @Fugazzy:

                          Super, danke,

                          ich habe die Initialisierung der Variablen mit in die Funktion genommen, da sonst der Zähler nicht zurück gesetzt wird und immer weiter zählt.

                          richtig?

                          Wie bekomme ich da nun noch die LEVEL der Dimmer mit hinein? (die haben ja einen STATE) `

                          Ja, richtig.

                          Ich hatte das im kommentierten Code oben schon geändert.

                          Ich habe leider keinen Dimmer und zu wenig Ahnung.

                          Was ist denn, wenn Du einen weitere Variable auf einen Selektor legst, mit *.LEVEL.

                          Und dann alles > 0 zählst.

                          Adapter: Fritzbox, Unify Circuit
                          Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                          1 Reply Last reply
                          0
                          • BluefoxB Offline
                            BluefoxB Offline
                            Bluefox
                            wrote on last edited by
                            #13

                            @Fugazzy:

                            Super, danke,

                            ich habe die Initialisierung der Variablen mit in die Funktion genommen, da sonst der Zähler nicht zurück gesetzt wird und immer weiter zählt.

                            richtig?

                            Wie bekomme ich da nun noch die LEVEL der Dimmer mit hinein? (die haben ja keinen STATE) `

                            createState('zählen.anzahlLichter', 0);    // wenn benötigt: Anzahl der vorhandenen Lichter
                            createState('zählen.anzahlLichterAn', 0);  // Anzahl der Lichter, die an sind als Variable unter Javascript.0 anlegen
                            
                            var cacheSelectorState  = $('channel[state.id=*.STATE](functions=Licht)');
                            var cacheSelectorDimmer = $('channel[state.id=*.LEVEL](functions=Licht)');
                            
                            function countLamps(obj) {
                                 // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk Licht auf 0
                                var anzahlLichterAn = 0;
                                var anzahlLichter = 0;
                            
                                log('New state of ' + 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 Licht
                                    var status = getState(id).val;                          // Zustand *.STATE abfragen (jedes Element)
                                    if (status === true) {++anzahlLichterAn}                // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                            //        log("Licht Nr. " + i + ": " + id + ": " + status);    // gibt alle Elemente *.STATE im Gewerk Licht mit dem aktuelle Status im Log aus
                                    ++anzahlLichter;                                        // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                                }); 
                                cacheSelectorDimmer.each(function (id, i) {                       // Schleife für jedes gefundenen Element *.STATE im Gewerk Licht
                                    var status = getState(id).val;                          // Zustand *.STATE abfragen (jedes Element)
                                    if (parseFloat(status) > 0) {++anzahlLichterAn}                // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                            //        log("Licht Nr. " + i + ": " + id + ": " + status);    // gibt alle Elemente *.STATE im Gewerk Licht mit dem aktuelle Status im Log aus
                                    ++anzahlLichter;                                        // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                                }); 
                            
                                // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                            
                                log("Anzahl Lichter: " + anzahlLichter + " # davon an: " + anzahlLichterAn);
                            
                                // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                                setState("zählen.anzahlLichter", anzahlLichter);        // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Licht
                                setState("zählen.anzahlLichterAn", anzahlLichterAn);    // Schreibt die aktuelle Anzahl der eingeschalteten Lichter
                            }
                            
                            cacheSelectorState.on(function(obj) {    // bei Zustandänderung *. STATE im Gewerk Licht
                            	countLamps(obj);
                            });
                            cacheSelectorDimmer.on(function(obj) {    // bei Zustandänderung *. LEVEL im Gewerk Licht
                            	countLamps(obj);
                            });
                            
                            
                            1 Reply Last reply
                            0
                            • F Offline
                              F Offline
                              Fugazzy
                              wrote on last edited by
                              #14

                              Die Hilfe hier ist ja den Hammer, vielen, vielen Dank!!!

                              Jetzt verstehe ich auch den "cacheSelectorState" etwas besser, auch wenn es noch etwas braucht . . .

                              Beim Funktionsaufruf fehlt jeweils (3 mal) noch (obj), oder?

                              1 Reply Last reply
                              0
                              • BluefoxB Offline
                                BluefoxB Offline
                                Bluefox
                                wrote on last edited by
                                #15

                                @Fugazzy:

                                Die Hilfe hier ist ja den Hammer, vielen, vielen Dank!!!

                                Jetzt verstehe ich auch den "cacheSelectorState" etwas besser, auch wenn es noch etwas braucht . . .

                                Beim Funktionsaufruf fehlt jeweils (3 mal) noch (obj), oder? `
                                Richtig :!: . Obwohl das nur für debug output benutzt wird.

                                1 Reply Last reply
                                0
                                • F Offline
                                  F Offline
                                  Fugazzy
                                  wrote on last edited by
                                  #16

                                  Hmm, es hat erst damit funktioniert. Vorher war erst obj unbekannt und dann noch id.

                                  Die Fehlermeldung hab ich gerade nicht mehr parat.

                                  Gruss Lutz

                                  1 Reply Last reply
                                  0
                                  • H Offline
                                    H Offline
                                    HKF8770
                                    wrote on last edited by
                                    #17

                                    Hallo,

                                    Supper Skript. Ich hätte aber noch 2 Punkte:

                                    log("Licht Nr. " + i + ": " + id + ": " + status); // gibt alle Elemente *.STATE im Gewerk Licht mit dem aktuelle Status im Log aus

                                    1. Hier bekommt man im Log die ID Nummer. Was muss anstatt id stehen dass ich den Name bekomme, Mach das Skript übersichtlicher.

                                    2. createState('zählen.textLichterAn', 0); // hab mir hier eine weitere Variable anlegen lassen, wo ich die Geräte wo === true ist dies ein Form eines Textes reingeschrieben werden.

                                    Wie müsste so was heissen?

                                    if (status === true) ???????????

                                    Sorry, bin grad noch beim lernen und hab keinen Ansatzpunkt

                                    Freddy

                                    1 Reply Last reply
                                    0
                                    • BluefoxB Offline
                                      BluefoxB Offline
                                      Bluefox
                                      wrote on last edited by
                                      #18

                                      @HKF8770:

                                      1. Hier bekommt man im Log die ID Nummer. Was muss anstatt id stehen dass ich den Name bekomme, Mach das Skript übersichtlicher. `

                                      log("Licht Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                                      
                                      

                                      @HKF8770:

                                      2. createState('zählen.textLichterAn', 0); // hab mir hier eine weitere Variable anlegen lassen, wo ich die Geräte wo === true ist dies ein Form eines Textes reingeschrieben werden.

                                      Wie müsste so was heissen?

                                      if (status === true) ??????????? `

                                          var anzahlLichter = 0;
                                          var textLichterAn = [];
                                      
                                          log('New state of ' + 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 Licht
                                              var status = getState(id).val;                          // Zustand *.STATE abfragen (jedes Element)
                                              var obj    = getObject(id);
                                              if (status === true || status === "true") {    // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                                                   textLichterAn.push(obj.common.name);    // Zu Array hinzufügen
                                              }                
                                              log("Licht Nr. " + i + ": " + obj.common.name + ": " + status);
                                              ++anzahlLichter;                                        // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                                          }); 
                                          setState("zählen.textLichterAn", textLichterAn.join(', '));    // Schreibt die aktuelle Namen der eingeschalteten Lichter
                                          setState("zählen.anzahlLichterAn", textLichterAn.length);    // Schreibt die aktuelle Anzahl der eingeschalteten Lichter
                                          setState("zählen.anzahlLichter", anzahlLichter);        // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Licht
                                          ...
                                      
                                      
                                      1 Reply Last reply
                                      0
                                      • H Offline
                                        H Offline
                                        HKF8770
                                        wrote on last edited by
                                        #19
                                        createState('zählen_Fenster.anzahlFenster', 0);    // wenn benötigt: Anzahl der vorhandenen Lichter
                                        createState('zählen_Fenster.anzahlFensterauf', 0);  // Anzahl der Lichter, die an sind als Variable unter Javascript.0 anlegen
                                        createState('zählen_Fenster.textFensterauf', " ");  // Anzahl der Lichter, die an sind als Variable unter Javascript.0 anlegen
                                        
                                        var cacheSelector = $('channel[state.id=*.STATE](functions=Fenster)');
                                        createState('zählen_Fenster.anzahlFenster', 0);    // wenn benötigt: Anzahl der vorhandenen Lichter
                                        createState('zählen_Fenster.anzahlFensterauf', 0);  // Anzahl der Lichter, die an sind als Variable unter Javascript.0 anlegen
                                        createState('zählen_Fenster.textFensterauf', " ");  // Text der Lichter, die an sind als Variable unter Javascript.0 anlegen
                                        
                                        var cacheSelectorState  = $('channel[state.id=*.STATE](functions=Fenster)');
                                        
                                        function countFenster(obj) {
                                             // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk Licht 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 Licht
                                                var status = getState(id).val;                          // Zustand *.STATE abfragen (jedes Element)
                                                var obj    = getObject(id);
                                                if (status === true) {    // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                                                     textFensterauf.push(obj.common.name);    // Zu Array hinzufügen
                                                }                
                                                log("Licht Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                                                ++anzahlFenster;                                        // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                                            }); 
                                        
                                            // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                                                log("Text: " + anzahlFensterauf);
                                                log("Anzahl Fesnter: " + anzahlFenster + " # davon Lichter 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(', '));    // Schreibt die aktuelle Namen der eingeschalteten Lichter
                                           setState("zählen_Fenster.anzahlFensterauf", textFensterauf.length);    // Schreibt die aktuelle Anzahl der eingeschalteten Lichter
                                           setState("zählen_Fenster.anzahlFenster", anzahlFenster);        // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Licht
                                        }
                                        
                                        cacheSelectorState.on(function(obj) {    // bei Zustandänderung *. STATE im Gewerk Fenster
                                           countFenster(obj);
                                        });
                                        

                                        212_widget_1.jpg

                                        Freddy

                                        1 Reply Last reply
                                        0
                                        • H Offline
                                          H Offline
                                          HKF8770
                                          wrote on last edited by
                                          #20

                                          Hab das Skript nun wie folgt erstellt und funktioniert.

                                          Danke an Bluefox !

                                          createState('zählen_Fenster.anzahlFenster', 0);    // wenn benötigt: Anzahl der vorhandenen Lichter
                                          createState('zählen_Fenster.anzahlFensterauf', 0);  // Anzahl der Lichter, die an sind als Variable unter Javascript.0 anlegen
                                          createState('zählen_Fenster.textFensterauf', " ");  // Anzahl der Lichter, die an sind als Variable unter Javascript.0 anlegen
                                          
                                          var cacheSelector = $('channel[state.id=*.STATE](functions=Fenster)');
                                          createState('zählen_Fenster.anzahlFenster', 0);    // wenn benötigt: Anzahl der vorhandenen Lichter
                                          createState('zählen_Fenster.anzahlFensterauf', 0);  // Anzahl der Lichter, die an sind als Variable unter Javascript.0 anlegen
                                          createState('zählen_Fenster.textFensterauf', " ");  // Text der Lichter, die an sind als Variable unter Javascript.0 anlegen
                                          
                                          var cacheSelectorState  = $('channel[state.id=*.STATE](functions=Fenster)');
                                          
                                          function countFenster(obj) {
                                               // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk Licht 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 Licht
                                                  var status = getState(id).val;                          // Zustand *.STATE abfragen (jedes Element)
                                                  var obj    = getObject(id);
                                                  if (status === true) {    // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                                                       textFensterauf.push(obj.common.name);    // Zu Array hinzufügen
                                                  }                
                                                  log("Licht Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                                                  ++anzahlFenster;                                        // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                                              }); 
                                          
                                              // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                                                  log("Text: " + anzahlFensterauf);
                                                  log("Anzahl Fesnter: " + anzahlFenster + " # davon Lichter 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(', '));    // Schreibt die aktuelle Namen der eingeschalteten Lichter
                                             setState("zählen_Fenster.anzahlFensterauf", textFensterauf.length);    // Schreibt die aktuelle Anzahl der eingeschalteten Lichter
                                             setState("zählen_Fenster.anzahlFenster", anzahlFenster);        // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Licht
                                          }
                                          
                                          cacheSelectorState.on(function(obj) {    // bei Zustandänderung *. STATE im Gewerk Fenster
                                             countFenster(obj);
                                          });
                                          
                                          

                                          In VIS sieht es nun so aus.

                                          Der Datenpunkten und der Widget zeigt Menge der offenen Fenster und im Dialog, sieht man welches dies sind.

                                          Datenpunkte auch schön in der Unterkategorie.
                                          212_widget_1.jpg
                                          212_widget.jpg

                                          Freddy

                                          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

                                          553

                                          Online

                                          32.4k

                                          Users

                                          81.3k

                                          Topics

                                          1.3m

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

                                          • Don't have an account? Register

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