Skip to content
  • Home
  • 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
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. [gelöst]Fehler bei subscribe(channel:"…

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    17
    1
    620

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    5.6k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.5k

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

Scheduled Pinned Locked Moved Skripten / Logik
106 Posts 22 Posters 21.7k 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.
  • F Offline
    F Offline
    f0rd42
    wrote on last edited by
    #97

    @MiB:

    ja, läuft bei mir. Wichtig ist nur, in den Objekten muss Fenster als Funktion stehen. Das Script sucht bei den Objekten mit Funktion Fenster ob da eine 0 - 1 oder 2 steht. Dann habe ich die Zeile:

    if (status /*TFK*/ || status === 1 || status === 2 /*SRH*/)
    

    geändert. Ich versteh den ersten Teil mit status /TFK/ nicht. Hab das gelöscht und es funktioniert. `

    Wass genau meinst du mit "…muss Fenster als Funktion stehen ...." es muss in einer Funktionsgruppe sein, die Fenster heisst, richtig? Habe ich. Frage nur: Hast du das komplette Gerät dort hineingepackt oder nur jeweils channel 1 (so wie es die HM automatisch machen würde)?

    Und was meinst Du mit "habe ich geändert"? In was? der Code den Du gepostet hast ist ja der Standard Code (ausser des SRH).

    Was genau hast Du gelöscht?

    Danke

    1 Reply Last reply
    0
    • M Offline
      M Offline
      MiB
      wrote on last edited by
      #98

      nein - ich hab auch nicht das ganze Gerät in die Gruppe Fenster gepackt sondern nur den Kanal der den State ausgibt. Wie du schon richtig sagst Channel 1

      gelöscht habe ich vorne den Teil : status /TFK/ wie ich geschrieben habe. Sieht bei mir also so aus:

      if (status === 1 || status === 2) {  // wenn Zustand offen...
      
      1 Reply Last reply
      0
      • M Offline
        M Offline
        MiB
        wrote on last edited by
        #99

        ach jetzt weiß ich wieder warum ich das gelöscht habe, der Fenterkontakt der HMIP gibt nicht true oder false aus sondern 0 oder 1

        1 Reply Last reply
        0
        • F Offline
          F Offline
          f0rd42
          wrote on last edited by
          #100

          geht bei mir trotzdem nicht …

          habe nun auch nur den Channel 1 drin und trotzdem (Neustart Script, Javascript Instanz, etc) alls auf "0"

          mein jetziges Script:

          /* System Zahl Fenster
          
          zählt die Fenster in allen Räumen und meldet die offenen Fenster namentlich
          Daten kommen vom Gewerk 'Fenster'
          
          erstellt: 17.06.2015 nach diesem Vorbild: http://forum.iobroker.net/viewtopic.php?f=21&t=869&sid=f9ba5657489ff431a1990884f90779c1#p6564
          05.08.2015 STATE aus der Ausgabe entfernt nach Idee von stephan61 http://forum.iobroker.org/viewtopic.php?f=21&t=473&start=20#p9267
          02.12.2015 Fehler beseitigt bei Anzahl Fenster, wenn offen (Unterscheidung SRH und TFK)
                     Überprüfung des Zustandes (function fensterstatus) und Übergabe an Text
          25.01.2016 Fenster Nummer in Log korrigiert (+1)
          02.03.2016 Ansage für TTS aufbereitet
          02.07.2016 Regulärer Ausdruck (gierig) bei Aufbereitung für Ansage
          */
          
          function fensterstatus(zustand) {
              var meldung;
              switch (zustand) {
                  case 1:
                      meldung = 'SRH gekippt';
                  break;
                  case 2:
                      meldung = 'SRH offen';
                  break;
                  case true:
                      meldung = 'TFK offen';
                  break;
                  default:
                      meldung = 'geschlossen';
                  break;
              }
              return(meldung);
          }
          
          createState('zählen_Fenster.anzahlFenster', {     // wenn benötigt: Anzahl der vorhandenen Fenster
              type: 'number',
              min: 0,
              def: 0,
              role: 'value'
          });
          createState('zählen_Fenster.anzahlFensterauf', {  // Anzahl der Fenster, die auf sind als Variable unter Javascript.0 anlegen
              type: 'number',
              min: 0,
              def: 0,
              role: 'value'
          });
          createState('zählen_Fenster.textFensterauf', {      // Anzahl der offenen Fenster und deren Namen als Variable unter Javascript.0 anlegen
              type: 'string',
              def: ' ',
              role: 'value'
          });    
          
          var cacheSelectorState  = $('channel[state.id=*.STATE](functions="Fenster")');
          
          function countFenster(obj) {
               // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk Fenster auf 0
              var anzahlFenster = 0;
              var anzahlFensterauf = 0;
              var textFensterauf = [];
          
              log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val);              // Info im Log, welcher Zustand sich geändert hat
          
              cacheSelectorState.each(function (id, i) {                                  // Schleife für jedes gefundenen Element *.STATE im Gewerk Fenster
                  var status = getState(id).val;                                          // Zustand *.STATE abfragen (jedes Element)
                  var obj    = getObject(id);
                  var name = getObject(id).common.name;
                  var devicename = name.substring(0, name.indexOf(".STATE"));             //.state aus Text entfernen
                  if (status === 1 || status === 2) {  // wenn Zustand offen, dann wird die Anzahl der Fenster hochgezählt
                       ++anzahlFensterauf;
                       textFensterauf.push(devicename + ' (' + fensterstatus(status) + ')');  // Name und Zustand zum Array hinzufügen
                  }                
                  log('Fenster #' + (i+1) + ': ' + devicename + ' ' + fensterstatus(status)/* + ' (' + status + ' / ' + typeof status + ')'*/);
                  ++anzahlFenster;                                                        // Zählt die Anzahl der vorhandenen Fenster unabhängig vom Status
              }); 
          
              // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                  log("Text: " + textFensterauf);
                  log("Anzahl Fenster: " + anzahlFenster + " - davon Fenster auf: " +  anzahlFensterauf);
          
              // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
              setState("zählen_Fenster.textFensterauf", textFensterauf.join(',
          '));    // Schreibt die aktuelle Namen der offenen Fenster
              setState("zählen_Fenster.anzahlFensterauf", textFensterauf.length);         // Schreibt die aktuelle Anzahl der offenen Fenster
              setState("zählen_Fenster.anzahlFenster", anzahlFenster);                    // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Fenster
          }
          
          cacheSelectorState.on(function(obj) {    // bei Zustandänderung *. STATE im Gewerk Fenster
              countFenster(obj);
          });
          
          // Variable für Ansage aufbereiten
          createState('zählen_Fenster.textFensteraufAnsage', {
              type: 'string',
              def: ' ',
              role: 'value'
          });  
          // Anzahl der Fenster, die auf sind, für Ansage aufbereitet
          var idQuelle = 'javascript.0.zählen_Fenster.textFensterauf',
              idAnsage = 'javascript.0.zählen_Fenster.textFensteraufAnsage';
          
          on(idQuelle, function (obj) {
              var text = obj.state.val;
              text = text.replace(/SRH/g, 'Drehgriff');
              text = text.replace(/TFK/g, 'Reedkontakt');
              text = (text.length > 1) ? 'Geöffnete Fenster: ' + text : 'Alle Fenster sind verschlossen';
              setState(idAnsage, text);
          });
          
          1 Reply Last reply
          0
          • M Offline
            M Offline
            MiB
            wrote on last edited by
            #101

            wieviel Fensterkontakte hast du? ich musste glaube mehrmals auf und zu machen und wenn möglich mehr als 1 bis es funktioniert hat. ich glaube hier steht auch im Threed irgendwo, manche mussten den ioBroker einmal neu starten bis es ging

            1 Reply Last reply
            0
            • F Offline
              F Offline
              f0rd42
              wrote on last edited by
              #102

              ich habe nun erstmal nur 4 hinzugefügt (habe 16).

              Auf und zu habe ich auch gemacht, status Änderung kommt in IObroker auch an.

              ich starte den iobroker nachher mal neu … mal sehen was dann passiert.

              1 Reply Last reply
              0
              • F Offline
                F Offline
                f0rd42
                wrote on last edited by
                #103

                nope, auch ein kompletter Neustart bringt nichts

                1 Reply Last reply
                0
                • M Offline
                  M Offline
                  MiB
                  wrote on last edited by
                  #104

                  also jetzt bin ich auch überfragt, hab da auch nicht DIE Ahnung um Fehlersuche zu betreiben. Hast du bei Funktion das Wort wie im Script stehen? Also groß und Kleinschreibung ist gleich. Hier mal wie es bei mir aussieht:

                  8590_fenster.png

                  1 Reply Last reply
                  0
                  • K Offline
                    K Offline
                    ktsalti
                    wrote on last edited by
                    #105

                    @dslraser:

                    Starte mal iobroker neu (oder zu mindest den Java Adapter, aber besser ganz neu starten, hat bei mir beim ersten benutzen des Script geholfen)

                    Und dann mal Fenster auf und zu `

                    Hey,

                    Danke - dein Tipp war Gold wert!! ich probiere hier schon einige Stunden rum (und wollte nicht gleich Fragen :)) warum meine Fenster nicht gezählt worden sind. Neustart vom Java-Adapter und es hat funktioniert… Juchu!!!

                    Gruß

                    Marcus

                    1 Reply Last reply
                    0
                    • F Offline
                      F Offline
                      Fuga
                      wrote on last edited by Fuga
                      #106

                      HI all,

                      ich bekomme das Script irgendwie nicht ans laufen.

                      Ich habe das Gewerk Fenster erstellt. Ich habe allen Fenster Kontakten im Namen das TFK vorrangestellt.
                      Bsp: TFK Wohnzimmer.
                      Das Script habe ich eins zu eins kopiert un gestartet. Die Variabeln wurden korrekt vom Script erstellt.
                      Leider bleibt zählen_Fenster.anzahlFenster bei 0.
                      Irgendwie erkennt er die Kontakte nicht.

                      Habe ich irgendetwas vergessen?

                      PS: Java Adapter habe ich auch neu gestartet

                      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

                      605

                      Online

                      32.7k

                      Users

                      82.6k

                      Topics

                      1.3m

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

                      • Don't have an account? Register

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