Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [gelöst]Fehler bei subscribe(channel:"…

    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]Fehler bei subscribe(channel:"…

    This topic has been deleted. Only users with topic management privileges can see it.
    • D
      dali3 last edited by

      Hallo Dutchmann

      Habe ich so eingepflegt, bei den Aufzählungen unter "enum.functions" zählt er die richtig auf (Bild 1).

      Aber bei Objekten sehe ich bei Status/Anzahl nur "0" (Bild 2).

      Obwohl z.B. ein Fenster offen ist (Bild 3).

      Was mache ich falsch? bzw. was muss ich anpassen falls keine Homematic Zentrale vorhanden ist?

      Danke viel mal!
      4746_1.jpg
      4746_2.jpg
      4746_3.jpg

      1 Reply Last reply Reply Quote 0
      • O
        ossilampe last edited by

        Cooles script, nur habe ich noch ein problem wie kann ich bei der ausgabe TFK und RHS weg machen, denn das interessiert ja nicht bei der ausgabe per google home

        1 Reply Last reply Reply Quote 0
        • T
          tempestas last edited by

          @dali3:

          Hallo Dutchmann

          Habe ich so eingepflegt, bei den Aufzählungen unter "enum.functions" zählt er die richtig auf (Bild 1).

          Aber bei Objekten sehe ich bei Status/Anzahl nur "0" (Bild 2).

          Obwohl z.B. ein Fenster offen ist (Bild 3).

          Was mache ich falsch? bzw. was muss ich anpassen falls keine Homematic Zentrale vorhanden ist?

          Danke viel mal! `

          Hi,

          versuche mal, in dem Skript bei

          var cacheSelector = $('channel[state.id=*.STATE](functions="Verschluss")');
          
          

          das draus zu machen

          var cacheSelector = $('channel[state.id=*.state](functions="Fenster")');
          
          
          1 Reply Last reply Reply Quote 0
          • D
            dali3 last edited by

            Hallo tempestas

            Meinst du im Skript von michihorn?

            1 Reply Last reply Reply Quote 0
            • T
              tempestas last edited by

              ähm… ich war davon ausgegangen, dass du ein Skript für die Fensterüberwachung genommen hast und ausprobiert hast und es nicht funktioniert? In dem Skript hatte ich geraten sei die Zeile, die zu ändern ich vorgeschlagen hatte.

              Hast du noch gar kein Skript am Start?

              1 Reply Last reply Reply Quote 0
              • D
                dali3 last edited by

                Das wäre mein jetziges Skript:

                Basis "michihorn"

                createState('zählenFenster.anzahlFenster', 0);    // wenn benötigt: Anzahl der vorhandenen Fenster
                createState('zählenFenster.anzahlFensterauf', 0);  // Anzahl der Fenster, die an sind als Variable unter Javascript.0 anlegen
                createState('zählenFenster.textFensterauf', " ");  // Text der Fenster, die an sind als Variable unter Javascript.0 anlegen
                
                var logging = true;
                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 Fenster
                        var status = getState(id).val;                          // Zustand *.STATE abfragen (jedes Element)
                        var obj    = getObject(id);
                        if (status === true || status >0) {    // wenn Zustand = true, dann wird die Anzahl der offenen Fenster hochgezählt
                             textFensterauf.push(obj.common.name);    // Zu Array hinzufügen
                        }                
                        log("Fenster Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                        ++anzahlFenster;                                        // Zählt die Anzahl der vorhandenen Fenster unabhängig vom Status
                    }); 
                
                    // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                        log("Text: " + anzahlFensterauf);
                        log("Anzahl Fenster: " + anzahlFenster + " # davon Fenster auf: " +  anzahlFensterauf);
                
                    // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                   setState("zählen_Fenster.textFensterauf", textFensterauf.join(',
                '));    // Schreibt die aktuelle Namen der eingeschalteten Fenster
                   setState("zählen_Fenster.anzahlFensterauf", textFensterauf.length);    // Schreibt die aktuelle Anzahl der eingeschalteten Fenster
                   setState("zählen_Fenster.anzahlFenster", anzahlFenster);        // Schreibt die aktuelle Anzahl der vorhandenen Elemente im Gewerk Fenster
                }
                
                cacheSelectorState.on(function(obj) {    // bei Zustandänderung *. STATE im Gewerk Fenster
                   countFenster(obj);
                });
                
                
                1 Reply Last reply Reply Quote 0
                • T
                  tempestas last edited by

                  und, funktioniert es?

                  1 Reply Last reply Reply Quote 0
                  • D
                    dali3 last edited by

                    Leider nicht 😞
                    4746_x1.jpg

                    1 Reply Last reply Reply Quote 0
                    • T
                      tempestas last edited by

                      Frage:

                      hast du denn mal ein Fenster geöffnet? Das Skript braucht einen Auslöser, damit etwas passiert. Also mal ein Fenster öffnen, oder aber du schreibst ans Ende des Skripts noch das hier:

                      // Bei Start
                        countFenster(obj);
                      
                      

                      Wenn das nichts bringt dann probier mal

                      var cacheSelectorState = $('state[id=*.state](functions="Fenster")');
                      

                      Auslöser muss natürlich auch dann eingebaut sein, also entweder Fenster öffnen oder den Skriptteil oben mit aufnehmen (schadet eh nichts, beim Start einmal durchlaufen zu lassen; es könnte ja sein, dass der JS Adapter sich mal neustartet, während ein Fenster offen ist. Das würde dann nicht erfasst. Also eh immer gut, beim Start einmal zu prüfen).

                      Ist nur ein Versuch. Wenn das auch nicht geht, komme ich etwas ans Ende.

                      1 Reply Last reply Reply Quote 0
                      • D
                        dali3 last edited by

                        Fenster öffnen habe ich versucht, passiert nichts.

                        // Bei Start

                        countFenster(obj); ist ja schon vorhanden, oder verstehe ich da etwas falsch?

                        Mit einem zweitem " countFenster(obj); "

                        erhalte ich einen Fehler.
                        4746_x2.jpg
                        4746_x3.jpg

                        1 Reply Last reply Reply Quote 0
                        • T
                          tempestas last edited by

                          nimm mal das (obj) raus bei dem "Bei Start" Teil

                          1 Reply Last reply Reply Quote 0
                          • D
                            dali3 last edited by

                            kein Fehler mehr, aber trotzdem zeigt er keine Werte 😕

                            Sollte ja gleich funktionieren wie bei LOWBAT via functions?
                            4746_x4.jpg
                            4746_x5.jpg
                            4746_x6.jpg

                            1 Reply Last reply Reply Quote 0
                            • T
                              tempestas last edited by

                              ok welche "cacheSelector" Varianten hast du denn jetzt probiert?

                              Du könntest als finalen Check nochmal das Original nehmen (naürlich mit "Fenster", nicht Verschluss) und das ausprobieren.

                              Wenn das auch nicht geht, weiß ich nichts mehr. Die Xiaomi funktionieren halt etwas anders.

                              Bzw. es gibt noch eine Variante, die aber (einmalig) mehr Arbeitsaufwand erfordert. Die könnten wir dann noch ausprobieren

                              1 Reply Last reply Reply Quote 0
                              • D
                                dali3 last edited by

                                Diesen:

                                createState('zählenFenster.anzahlFenster', 0);    // wenn benötigt: Anzahl der vorhandenen Fenster
                                createState('zählenFenster.anzahlFensterauf', 0);  // Anzahl der Fenster, die an sind als Variable unter Javascript.0 anlegen
                                createState('zählenFenster.textFensterauf', " ");  // Text der Fenster, die an sind als Variable unter Javascript.0 anlegen
                                
                                var logging = true;
                                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 Fenster
                                        var status = getState(id).val;                          // Zustand *.STATE abfragen (jedes Element)
                                        var obj    = getObject(id);
                                        if (status === true || status >0) {    // wenn Zustand = true, dann wird die Anzahl der offenen Fenster hochgezählt
                                             textFensterauf.push(obj.common.name);    // Zu Array hinzufügen
                                        }                
                                        log("Fenster Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                                        ++anzahlFenster;                                        // Zählt die Anzahl der vorhandenen Fenster unabhängig vom Status
                                    }); 
                                
                                    // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                                        log("Text: " + anzahlFensterauf);
                                        log("Anzahl Fenster: " + anzahlFenster + " # davon Fenster auf: " +  anzahlFensterauf);
                                
                                    // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                                   setState("zählen_Fenster.textFensterauf", textFensterauf.join(',
                                '));    // Schreibt die aktuelle Namen der eingeschalteten Fenster
                                   setState("zählen_Fenster.anzahlFensterauf", textFensterauf.length);    // Schreibt die aktuelle Anzahl der eingeschalteten Fenster
                                   setState("zählen_Fenster.anzahlFenster", anzahlFenster);        // Schreibt die aktuelle Anzahl der vorhandenen Elemente im Gewerk Fenster
                                }
                                
                                cacheSelectorState.on(function(obj) {    // bei Zustandänderung *. STATE im Gewerk Fenster
                                  countFenster(obj);
                                });
                                
                                // Bei Start
                                countFenster;
                                
                                
                                1 Reply Last reply Reply Quote 0
                                • T
                                  tempestas last edited by

                                  Bitte:

                                  // Bei Start
                                  countFenster();
                                  

                                  und dann nochmal probieren.

                                  hattest du diese Variante

                                  var cacheSelectorState = $('channel[state.id=*.state](functions="Fenster")');
                                  

                                  denn auch getestet durch Öffnen eines Fensters bzw durch Anfügen dieses Teils:

                                  // Bei Start
                                  countFenster();
                                  

                                  ?? Das ist mir nicht ganz klar.

                                  1 Reply Last reply Reply Quote 0
                                  • D
                                    dali3 last edited by

                                    ja habe alle Varianten getestet:

                                    Theoretisch sollte zumindest die Anzahl Fenster angezeigt werden oder?

                                    Mit den beiden Klammern erhalte ich nun diese Fehlermeldungen im Log:
                                    4746_x7.jpg

                                    1 Reply Last reply Reply Quote 0
                                    • T
                                      tempestas last edited by

                                      ah ja mit den Klammern ist klar. Ignorier das mal.

                                      Nein, es sollten keine Fenster angezeigt werden, denn die "möglichen Fenster" werden auch erst im Rahmen des Skripthochlaufs gezählt

                                      Dann gibt es jetzt die nachfolgende Möglichkeit. Macht etwas mehr Arbeit, sollte aber gehen

                                      ! ```
                                      `// Skript zum prüfen, wieviele Fenster offen sind
                                      // Lösung für Xiaomi Kontakte, die nicht via $-Selector ansprechbar zu sein scheinen
                                      // Status: 4.1.2018
                                      ! // ############ ALLGEMEINE SKRIPTEINSTELLUNGEN ###############
                                      ! // debugging
                                      ! var debug = false;
                                      ! // states
                                      ! createState('Fenster.Total', 0);
                                      createState('Fenster.Offen', 0);
                                      ! // ################## Fenster Kontakte #####################
                                      ! var idFenster1 = ["mihome.0.devices.magnet_158d0001dacfc1.state"/Is opened Fenster Küche offen/] , // ids eintragen, geht rechts oben im JS Editor, "id einfügen". Dort auf den "open" state verlinken.
                                      idFenster2 = ["mihome.0.devices.magnet_158d0001dacfc7.state"/Is opened Fenster Wohnzimmer offen/
                                      ! // Variablen / IDs deklarieren
                                      ! var idFenster1 = "mihome.0.devices.magnet_158d0001dacfc1.state"/Is opened Fenster Küche offen/, // ids eintragen, geht rechts oben im JS Editor, "id einfügen". Dort auf den "open" state verlinken.
                                      idFenster2 = "mihome.0.devices.magnet_158d0001dacfc7.state"/Is opened Fenster Wohnzimmer offen/; // du kannst die Variablen auch "FensterKueche" usw nennen, es muss nicht "idFenster1" sein
                                      // idFenster3 = [HIER DIE ID DEINER MAGNETEN EINFÜGEN] , // die IDs kannst du beliebig benennen. Müssen aber nachfolgend entsprechend eingetragen sein
                                      // idFensterN = [HIER DIE ID DEINER MAGNETEN EINFÜGEN] ; // die letzte ID muss mit einem Semikolon beendet werden, dazwischen Kommas
                                      ! var arrFenster = [idFenster1, idFenster2]; // hier musst du die gleichen Namen eintragen, wie du direkt hierüber eingestellt hast
                                      ! // Variablen

                                      var countOffen = 0;
                                      countTotal =arrFenster.length;

                                      ! // ######## FUNKTIONEN ########
                                      ! on(arrFenster, function(obj){
                                      ! var status = obj.state.val;

                                          if(status){
                                              ++countOffen; 
                                              countOffen= Math.min(arrFenster.length, countOffen);
                                              if(debug) log("Es sind "+countOffen +" Fenster offen");
                                          }
                                          else{
                                              --countOffen;
                                              countOffen = Math.max(0, countOffen);
                                              if(debug) log("Es sind "+countOffen +" Fenster offen");
                                          }
                                      

                                      ! setState("javascript.0.Fenster.Offen", countOffen);
                                      setState("javascript.0.Fenster.Total", countTotal);
                                      });

                                      // ############# BEI SKIRPTSTART DIE COUNTER RICHTIG SETZEN ###################

                                      ! for (var i = 0; i< arrFenster.length; i++) {
                                      var objekt = arrFenster[i];
                                      var value = getState(objekt).val;
                                      if(debug) log(arrFenster[i] + " ist " +value);
                                      if(value) ++countOffen;
                                      setState("javascript.0.Fenster.Offen", countOffen);
                                      }` [/i][/i]

                                      1 Reply Last reply Reply Quote 0
                                      • D
                                        dali3 last edited by

                                        so alles angepasst und eingefügt via iobroker.pro da ich unterwegs bin.

                                        Code:

                                        ! ```
                                        `// Skript zum prüfen, wieviele Fenster offen sind
                                        // Lösung für Xiaomi Kontakte, die nicht via $-Selector ansprechbar zu sein scheinen
                                        // Status: 4.1.2018
                                        ! // ############ ALLGEMEINE SKRIPTEINSTELLUNGEN ###############
                                        ! // debugging
                                        ! var debug = false;
                                        ! // states
                                        ! createState('Fenster.Total', 0);
                                        createState('Fenster.Offen', 0);
                                        ! // ################## Fenster Kontakte #####################
                                        ! // Variablen / IDs deklarieren
                                        ! var idFenster1 = ["mihome.0.devices.magnet_158d0001dacfc1.state"/Is opened Fenster Küche offen/] , // ids eintragen, geht rechts oben im JS Editor, "id einfügen". Dort auf den "open" state verlinken.
                                        idFenster2 = ["mihome.0.devices.magnet_158d0001dacfc7.state"/Is opened Fenster Wohnzimmer offen/] ; // du kannst die Variablen auch "FensterKueche" usw nennen, es muss nicht "idFenster1" sein
                                        //idFenster3 = [HIER DIE ID DEINER MAGNETEN EINFÜGEN] , // die IDs kannst du beliebig benennen. Müssen aber nachfolgend entsprechend eingetragen sein
                                        //idFensterN = [HIER DIE ID DEINER MAGNETEN EINFÜGEN] ; // die letzte ID muss mit einem Semikolon beendet werden, dazwischen Kommas
                                        ! var arrFenster = [idFenster1, idFenster2]; // hier musst du die gleichen Namen eintragen, wie du direkt hierüber eingestellt hast
                                        ! // Variablen

                                        var countOffen = 0;
                                        countTotal =arrFenster.length;

                                        ! // ######## FUNKTIONEN ########
                                        ! on(arrFenster, function(obj){
                                        ! var status = obj.state.val;

                                            if(status){
                                                ++countOffen; 
                                                countEG= Math.min(arrFenster.length, countOffen);
                                                if(debug) log("Es sind "+countOffen +" Fenster offen");
                                            }
                                            else{
                                                --countOffen;
                                                countOffen = Math.max(0, countOffen);
                                                if(debug) log("Es sind "+countOffen +" Fenster offen");
                                            }
                                        

                                        ! setState("javascript.0.Fenster.Offen", countOffen);
                                        setState("javascript.0.Fenster.Total", countTotal);
                                        });

                                        // ############# BEI SKIRPTSTART DIE COUNTER RICHTIG SETZEN ###################

                                        ! for (var i = 0; i< arrFenster.length; i++) {
                                        var objekt = arrFenster[i];
                                        var value = getState(objekt).val;
                                        if(debug) log(arrFenster[i] + " ist " +value);
                                        if(value) ++countFenster;
                                        setState("javascript.0.Fenster.Offen", countOffen);
                                        }`
                                        Hier der Status:
                                        ! Werde es sicher heute Abend zu Hause nochmals sauber testen und dir ein Feedback geben! Danke viel mal!!
                                        4746_x8.jpg
                                        4746_x9.jpg [/i][/i]

                                        1 Reply Last reply Reply Quote 0
                                        • T
                                          tempestas last edited by

                                          Habe das Skript oben angepasst und deine beiden Kontakte eingetragen als Beispiel; da hattest du noch einen kleinen Verständnisfehler. Die [] gehörten zu meinem Kommentar und nicht zum Code. Waren noch zwei Übertragungsfehler drin. Ich habe letztlich nur schnell mein Hue-Lampenskript abgewandelt auf Fenster.

                                          Bitte setze Skripte hier im Forum immer in die Code Tags, das macht das lesen viel leichter

                                          Hi

                                          1 Reply Last reply Reply Quote 0
                                          • D
                                            dali3 last edited by

                                            hat sich noch ein kleiner Kopierfehler eingeschlichen:

                                            ! var idFenster1 = ["mihome.0.devices.magnet_158d0001dacfc1.state"/Is opened Fenster Küche offen/] , // ids eintragen, geht rechts oben im JS Editor, "id einfügen". Dort auf den "open" state verlinken.
                                            ! idFenster2 = ["mihome.0.devices.magnet_158d0001dacfc7.state"/Is opened Fenster Wohnzimmer offen/[/spoiler]

                                            Code:

                                            ! ```
                                            `// Skript zum prüfen, wieviele Fenster offen sind
                                            // Lösung für Xiaomi Kontakte, die nicht via $-Selector ansprechbar zu sein scheinen
                                            // Status: 4.1.2018
                                            ! // ############ ALLGEMEINE SKRIPTEINSTELLUNGEN ###############
                                            ! // debugging
                                            ! var debug = false;
                                            ! // states
                                            ! createState('Fenster.Total', 0);
                                            createState('Fenster.Offen', 0);
                                            ! // ################## Fenster Kontakte #####################
                                            ! // Variablen / IDs deklarieren
                                            ! var idFenster1 = "mihome.0.devices.magnet_158d0001dacfc1.state"/Is opened Fenster Küche offen/, // ids eintragen, geht rechts oben im JS Editor, "id einfügen". Dort auf den "open" state verlinken.
                                            idFenster2 = "mihome.0.devices.magnet_158d0001dacfc7.state"/Is opened Fenster Wohnzimmer offen/; // du kannst die Variablen auch "FensterKueche" usw nennen, es muss nicht "idFenster1" sein
                                            // idFenster3 = [HIER DIE ID DEINER MAGNETEN EINFÜGEN] , // die IDs kannst du beliebig benennen. Müssen aber nachfolgend entsprechend eingetragen sein
                                            // idFensterN = [HIER DIE ID DEINER MAGNETEN EINFÜGEN] ; // die letzte ID muss mit einem Semikolon beendet werden, dazwischen Kommas
                                            ! var arrFenster = [idFenster1, idFenster2]; // hier musst du die gleichen Namen eintragen, wie du direkt hierüber eingestellt hast
                                            ! // Variablen

                                            var countOffen = 0;
                                            countTotal =arrFenster.length;

                                            ! // ######## FUNKTIONEN ########
                                            ! on(arrFenster, function(obj){
                                            ! var status = obj.state.val;

                                                if(status){
                                                    ++countOffen; 
                                                    countOffen= Math.min(arrFenster.length, countOffen);
                                                    if(debug) log("Es sind "+countOffen +" Fenster offen");
                                                }
                                                else{
                                                    --countOffen;
                                                    countOffen = Math.max(0, countOffen);
                                                    if(debug) log("Es sind "+countOffen +" Fenster offen");
                                                }
                                            

                                            ! setState("javascript.0.Fenster.Offen", countOffen);
                                            setState("javascript.0.Fenster.Total", countTotal);
                                            });

                                            // ############# BEI SKIRPTSTART DIE COUNTER RICHTIG SETZEN ###################

                                            ! for (var i = 0; i< arrFenster.length; i++) {
                                            var objekt = arrFenster[i];
                                            var value = getState(objekt).val;
                                            if(debug) log(arrFenster[i] + " ist " +value);
                                            if(value) ++countOffen;
                                            setState("javascript.0.Fenster.Offen", countOffen);
                                            }`
                                            ! nun werden die offen Fenster gezählt!
                                            ! Wie gross wäre der Aufwand den Text mit zu senden? (Analog Lowbat)
                                            4746_x10.jpg
                                            4746_x11.jpg [/i][/i]

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            934
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            22
                                            106
                                            17573
                                            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