Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

  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.4k

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

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

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

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
106 Beiträge 22 Kommentatoren 19.8k Aufrufe 1 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • F Offline
    F Offline
    f0rd42
    schrieb am zuletzt editiert von
    #95

    @MiB:

    Hallo,

    kann es sein das es an der Bezeichnung der HM IP Geräte liegt. Bin auch gerade auf dieses Script aufmerksam geworden und habe festgestellt, bei mir heißen die Geräte nicht RHS sondern SRH. Hab das einfach umgeändert, kann es aber noch nicht bestätigen weil ich noch an der Arbeit bin.

    Grüße Michael `

    Genau das ist mir auch aufgefallen, jedoch funktioniert es bei mir trotzdem nicht.

    Ich habe in der CCU keine Gewerke angelegt, aber in iobroker eine manuelle enum angelegt mit allen SRH drin. Trotzdem funktioniert es nciht, alles steht auf "0".

    Hast Du es denn mit den HM-IP ans laufen bekommen?

    mein derzeitiges 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 … 79c1#p6564
    ! 05.08.2015 STATE aus der Ausgabe entfernt nach Idee von stephan61 http://forum.iobroker.org/viewtopic.php ... t=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 = $('channelstate.id=*.STATE');
    ! 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 /TFK/ || status === 1 || status === 2 /SRH/) { // 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 Antwort Letzte Antwort
    0
    • M Offline
      M Offline
      MiB
      schrieb am zuletzt editiert von
      #96

      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.

      1 Antwort Letzte Antwort
      0
      • F Offline
        F Offline
        f0rd42
        schrieb am zuletzt editiert von
        #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 Antwort Letzte Antwort
        0
        • M Offline
          M Offline
          MiB
          schrieb am zuletzt editiert von
          #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 Antwort Letzte Antwort
          0
          • M Offline
            M Offline
            MiB
            schrieb am zuletzt editiert von
            #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 Antwort Letzte Antwort
            0
            • F Offline
              F Offline
              f0rd42
              schrieb am zuletzt editiert von
              #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 Antwort Letzte Antwort
              0
              • M Offline
                M Offline
                MiB
                schrieb am zuletzt editiert von
                #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 Antwort Letzte Antwort
                0
                • F Offline
                  F Offline
                  f0rd42
                  schrieb am zuletzt editiert von
                  #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 Antwort Letzte Antwort
                  0
                  • F Offline
                    F Offline
                    f0rd42
                    schrieb am zuletzt editiert von
                    #103

                    nope, auch ein kompletter Neustart bringt nichts

                    1 Antwort Letzte Antwort
                    0
                    • M Offline
                      M Offline
                      MiB
                      schrieb am zuletzt editiert von
                      #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 Antwort Letzte Antwort
                      0
                      • K Offline
                        K Offline
                        ktsalti
                        schrieb am zuletzt editiert von
                        #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 Antwort Letzte Antwort
                        0
                        • F Offline
                          F Offline
                          Fuga
                          schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                          0
                          Antworten
                          • In einem neuen Thema antworten
                          Anmelden zum Antworten
                          • Älteste zuerst
                          • Neuste zuerst
                          • Meiste Stimmen


                          Support us

                          ioBroker
                          Community Adapters
                          Donate

                          256

                          Online

                          32.4k

                          Benutzer

                          81.4k

                          Themen

                          1.3m

                          Beiträge
                          Community
                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                          ioBroker Community 2014-2025
                          logo
                          • Anmelden

                          • Du hast noch kein Konto? Registrieren

                          • Anmelden oder registrieren, um zu suchen
                          • Erster Beitrag
                            Letzter Beitrag
                          0
                          • Home
                          • Aktuell
                          • Tags
                          • Ungelesen 0
                          • Kategorien
                          • Unreplied
                          • Beliebt
                          • GitHub
                          • Docu
                          • Hilfe