Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Skript LOWBAT

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Skript LOWBAT

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

      Ich muss mich korrigieren, weil ich das Script nicht gespeichert hatte!

      Hiermit werden die Logs nicht mehrfach geschrieben:

      var cacheSelectorLOWBAT  = $('hm-rpc.1.*.0.LOWBAT');
      
      

      Mit diesem Code:

      var cacheSelectorLOWBAT  = $('channel[state.id=hm-rpc.1.*.0.LOWBAT]');
      
      

      werden zusätzlich die LOWBAT_ALARM Einträge ausgegeben (also doppelte Anzahl).

      Und falls noch jemand oder du paul53 eine Idee zu den Aktoren ohne Batterie (LOWBAT) habt, dann immer gerne her damit 8-)

      Danke noch einmal bis hierhin.

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

        @nukleuz:

        werden zusätzlich die LOWBAT_ALARM Einträge ausgegeben (also doppelte Anzahl). `
        Dann versuche mal

        var cacheSelectorLOWBAT  = $('channel[state.id=hm-rpc.1.*.0.LOWBAT$]');
        

        @nukleuz:

        Und falls noch jemand oder du paul53 eine Idee zu den Aktoren ohne Batterie (LOWBAT) habt, dann immer gerne her damit `
        Da fällt mir nur ein, die betreffenden Datenpunkte im Reiter "Objekte" zu löschen.

        1 Reply Last reply Reply Quote 0
        • nukleuz
          nukleuz last edited by

          Der Versuch hat auch super geklappt und das Löschen versuche ich gleich und gebe Rückinfo.

          Danke!

          1 Reply Last reply Reply Quote 0
          • nukleuz
            nukleuz last edited by

            Das Löschen der LOWBAT Datenpunkte kommt wieder, sobald ich die HM-Geräte über den Adapter HM-RPC.1 einmalig neu initialisiere.

            Das wird zukünftig auch immer mal wieder passieren, wenn neue Geräte von HomeMatic hinzukommen.

            Ich denke, dass ich den Versuch starten werde, über das Gewerk "Batterie" der in der CCU2 gesetzt und auch in iobroker übernommen wird, die Geräte zu holen.

            Dazu gibt es hier ja den ein oder anderen Codeschnipsel…

            Oder habt ihr noch andere/weitere Ideen was das sein könnte?

            Bin ich der einzige bei dem der LOWBAT Status in NICHT-batteriebetriebenen Komponenten auftaucht?

            Grüße

            EDIT: Unterputzdimmer (Aktoren) und mein Zwischenstecker mit Messung sind da übrigens nicht von betroffen.

            1 Reply Last reply Reply Quote 0
            • S
              Saschag last edited by

              Hallo zusammen,

              ich bekomme das Skript leider nicht zum laufen. Es werden keine Geräte erkannt. 😞 😞

              createState('zählenLowbat.möglicheLOWBAT', 0);   // wenn benötigt: Anzahl der vorhandenen LOWBAT
              createState('zählenLowbat.anzahlLOWBAT', 0);     // wenn benötigt: Anzahl der vorhandenen LOWBAT
              createState('zählenLowbat.textLOWBAT', " ");     // Anzahl LOWBAT, die an sind als Variable unter Javascript.0 anlegen
              
              var cacheSelectorLOWBAT  = $('channel[state.id=*.LOWBAT]');
              
              function countLowbat(obj) {
              	// Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
              	var moeglicheLOWBAT = 0;
              	var anzahlLOWBAT    = 0;
              	var textLOWBAT      = [];
              
              	if (obj) {
              		log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val);  // Info im Log, welcher Zustand sich geändert hat
              	} else {
              		log('Ausgelöst bei Timer'); 
              	} 
              
              	cacheSelectorLOWBAT.each(function (id, i) {                         // Schleife für jedes gefundenen Element *.LOWBAT
              		var status = getState(id).val;                                  // Zustand *.LOWBAT abfragen (jedes Element)
              		var obj    = getObject(id);
              		if (status === true) {                                          // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
              			textLOWBAT.push(obj.common.name);                           // Zu Array hinzufügen
              		}                
              		log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
              		++anzahlLOWBAT;                                                 // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
              	}); 
              
              	// Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
              	log("Text: " + textLOWBAT);
              	log("Anzahl Geräte: " + moeglicheLOWBAT + " # davon LOWBAT erkannt: " +  anzahlLOWBAT);
              
              	// die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
              	setState("zählenLowbat.textLOWBAT",     textLOWBAT.join(',
              ')); // Schreibt die aktuelle Namen der Geräte mit LOWBAT Meldung
              	setState("zählenLowbat.anzahlLOWBAT",   textLOWBAT.length);        // Schreibt die aktuelle Anzahl der Geräte im System
              	setState("zählenLowbat.möglicheLOWBAT", moeglicheLOWBAT);          // Schreibt die aktuelle Anzahl der vorhandene Geräte 
              }
              
              cacheSelectorLOWBAT.on(function(obj) {    // bei Zustandänderung *. LOWBAT in allen Gewerken
                 countLowbat(obj);
              });
              schedule("*/60 * * * *", function () {                                  //oder!! soll entweder ausgelöst werden alle 10 Minuten
                 log("===>Will be triggered every 60 minutes!"); 
                 countLowbat();
              });
              

              Ich hoffe es hat einer eine Idee???!!!

              Grüße

              Sascha
              1532_lowbat.png
              1532_bildschirmfoto_2019-02-01_um_20.50.54.png
              1532_4d2b9cce-5573-4805-9d1f-32fd4dce1ad2.jpeg

              1 Reply Last reply Reply Quote 0
              • S
                Saschag last edited by

                Keine ne Idee?? Warum es nicht klappt 😞 😐

                Jetzt habe dies im LOG aber die Datenpunkte sind immer noch beide 0
                1532_ddbbdd68-fb47-4a82-94bb-f31744d334bc.jpeg

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

                  Das Skript enthält einen Fehler. Bitte korrigieren:

                  		log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                  		++moeglicheLOWBAT;                                                 // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                  	}); 
                  
                  
                  1 Reply Last reply Reply Quote 0
                  • S
                    Saschag last edited by

                    @paul53

                    Super klappt!

                    Vielen Dank!!!

                    Edit: Danke nochmal! Habe nun auch verstanden wo der Fehler war und das dies schon ein paar mal im Fed Thema war 😉 😞

                    Deshalb noch mal Danke! 😄

                    1 Reply Last reply Reply Quote 0
                    • X
                      Xanon last edited by

                      Hallo,
                      ich setzte dieses Skript ein, um mich über leere Batterien informieren zu lassen.

                      //Add device rules
                      addDeviceCounter("lowbat_ip",      $('channel[state.id=*.LOW_BAT]'),                     true);
                      addDeviceCounter("lowbat",         $('channel[state.id=*.LOWBAT]'),                      true);
                      addDeviceCounter("sticky_unreach", $('channel[state.id=*.STICKY_UNREACH]'),              true);
                      addDeviceCounter("unreach",        $('channel[state.id=*.UNREACH]'),                     true);
                      addDeviceCounter("config_pending", $('channel[state.id=*.CONFIG_PENDING]'),              true);
                      //addDeviceCounter("open_windows",   $('channel{TYPE=SHUTTER_CONTACT}[state.id=*.STATE]'), true);
                      //addDeviceCounter("on_lights",      $('channel{TYPE=DIMMER}[state.id=*.LEVEL]'),          function(state){return state>0;});
                      addDeviceCounter("open_shutters",  $('channel{TYPE=BLIND}[state.id=*.LEVEL]'),           function(state){return state>0;});
                      //addDeviceCounter("playing_music",  $('channel[state.id=*audio-*.playing]'),              true);
                      
                      /******************************************
                       * Code - do not change anything bellow this line *
                       ******************************************/
                      
                      function addDeviceCounter(name, selector, val_to_count) {
                      
                          //Total amount of devices found by selector
                          var state_total = 'deviceCounter.' + name + '.total';
                          createState(state_total, 0);
                          //List of devices that match condition
                          var state_list = 'deviceCounter.' + name + '.list';
                          createState(state_list, "");
                          //Number of devices that match condition
                          var state_counter = 'deviceCounter.' + name + '.counter';
                      
                          createState(state_counter, 0);
                          function countDevs(obj) {
                              var d_count = 0;
                              var d_list  = [];
                      
                              selector.each(function (id, i) {
                                  var status = getState(id).val;
                                  var obj    = getObject(id);
                                  if ((typeof val_to_count === 'function' && val_to_count(status)) ||
                                      (typeof val_to_count === 'boolean'  && val_to_count == status)) {
                                      //Get parent object
                                      var parentChannelId = id.slice(id.lastIndexOf("."));
                                      var parentDevicelId = id.split(".").slice(0,-2).join(".");
                                      var deviceObject = getObject(parentDevicelId);
                                      //remember device name
                                      d_list.push(deviceObject.common.name);
                                  }                
                                  ++d_count;                                                 // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                              }); 
                      
                              log(name + "(" + d_count + "): " + d_list);
                      
                              setState(state_list,     d_list.join(' '));
                              setState(state_counter,  d_list.length);
                              setState(state_total,    d_count);
                          }
                      
                          //Re-evaluate when a device status changes
                          selector.on(function(obj) {    // bei Zustandänderung *. LOWBAT in allen Gewerken
                              countDevs(obj);
                          });
                      
                          //Re-evaluate each hour
                          schedule("*/1 * * * *", countDevs);
                      
                          //Evaluate for the first time
                          countDevs();
                      }
                      
                      

                      Ich habe LOWBAT und LOW_BAT (also IP Komponenten) im Einsatz.
                      Nun wollte ich gerne die beiden States zu einer LOWBAT State zusammenfügen.
                      Habe es mit

                      addDeviceCounter("lowbat",      $('channel[state.id=*.LOW_BAT]'),                     true);
                      addDeviceCounter("lowbat",         $('channel[state.id=*.LOWBAT]'),                      true);
                      

                      versucht, aber statt beide States zusammenzuzählen werden mir bei jedem Timer Event (steht zu Testzwecken auf 1 Min.) mal der eine angezeigt / angesagt und mal der andere.

                      Gibt es überhaupt eine Möglichkeit beide States in einem LOWBAT anzeigen zu lassen?
                      Kann mir einer sagen, was ich falsch mache oder anders machen muß?

                      Vielen Dank schon mal für die Hilfe.

                      Gruß
                      Xanon

                      Fogg 1 Reply Last reply Reply Quote 1
                      • A
                        Alveran last edited by

                        Hallo,

                        wo findet man die letzte Version vom Script?

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

                          Hallo zusammen,

                          seit einiger Zeit habe ich ebenfalls Probleme mit dem Script.
                          Es zählt immer die Geräte bis Geräte Nr. 83, danach erscheinen folgende Fehlermeldungen im Log:

                          09:00:00.010	info	javascript.0 (848) script.js.common.Lowbat: Geräte Nr. 81: Bewegungsmelder vor Garage Haus:0.LOWBAT: false
                          09:00:00.011	info	javascript.0 (848) script.js.common.Lowbat: Geräte Nr. 82: Licht Buehne Garage:0.LOWBAT: false
                          09:00:00.011	info	javascript.0 (848) script.js.common.Lowbat: Geräte Nr. 83: LED Bild Pavillion:0.LOWBAT: false
                          09:00:00.011	warn	javascript.0 (848) at script.js.common.Lowbat:20:10
                          09:00:00.011	warn	javascript.0 (848) at countLowbat (script.js.common.Lowbat:18:24)
                          09:00:00.011	warn	javascript.0 (848) at Object.<anonymous> (script.js.common.Lowbat:46:4)
                          09:00:00.013	warn	javascript.0 (848) at script.js.common.Lowbat:21:19
                          09:00:00.013	warn	javascript.0 (848) at countLowbat (script.js.common.Lowbat:18:24)
                          09:00:00.013	warn	javascript.0 (848) at Object.<anonymous> (script.js.common.Lowbat:46:4)
                          09:00:00.014	error	javascript.0 (848) at script.js.common.Lowbat:27:51
                          09:00:00.014	error	javascript.0 (848) at countLowbat (script.js.common.Lowbat:18:24)
                          09:00:00.014	error	javascript.0 (848) at Object.<anonymous> (script.js.common.Lowbat:46:4)
                          

                          Das Script sieht so aus:

                          createState('zählenLowbat.möglicheLOWBAT', 0);   // wenn benötigt: Anzahl der Geräte mit Batterie
                          createState('zählenLowbat.anzahlLOWBAT', 0);     // wenn benötigt: Anzahl der vorhandenen LOWBAT
                          createState('zählenLowbat.textLOWBAT', " ");     // Namen LOWBAT, die an sind als Variable unter Javascript.0 anlegen
                          
                          var cacheSelectorLOWBAT  = $('channel[state.id=*0.LOWBAT]');
                          
                          function countLowbat(obj) {
                             // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
                             var moeglicheLOWBAT = 0;
                             var textLOWBAT      = [];
                          
                             if (obj) {
                                log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val);  // Info im Log, welcher Zustand sich geändert hat
                             } else {
                                log('Ausgelöst bei Timer');
                             }
                          
                             cacheSelectorLOWBAT.each(function (id, i) {                         // Schleife für jedes gefundenen Element *0.LOWBAT
                                var status = false;
                                if(getState(id)) {
                                   status = getState(id).val;                                  // Zustand *0.LOWBAT abfragen (jedes Element)
                                }   
                                var obj    = getObject(id);
                                if (status === true) {                                          // wenn Zustand = true, wird das Array erweitert
                                   textLOWBAT.push(obj.common.name);                           // Zu Array hinzufügen
                                }               
                                log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                                ++moeglicheLOWBAT;                                                 // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                             });
                          
                             // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
                             log("Text: " + textLOWBAT);
                             log("Anzahl Geräte: " + moeglicheLOWBAT + " # davon LOWBAT erkannt: " +  textLOWBAT.length);
                          
                             // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                             setState("zählenLowbat.textLOWBAT",     textLOWBAT.join(',<br>')); // Schreibt die Namen der Geräte mit LOWBAT Meldung
                             setState("zählenLowbat.anzahlLOWBAT",   textLOWBAT.length);        // Schreibt die aktuelle Anzahl der LOWBAT-Meldungen
                             setState("zählenLowbat.möglicheLOWBAT", moeglicheLOWBAT);          // Schreibt die Anzahl der vorhandenen Batterie-Geräte
                          }
                          
                          cacheSelectorLOWBAT.on(function(obj) {    // bei Zustandänderung *. LOWBAT in allen Gewerken
                             countLowbat(obj);
                          });
                          schedule("*/60 * * * *", function () {                                  //oder!! soll entweder ausgelöst werden alle 10 Minuten
                             log("===>Will be triggered every 60 minutes!");
                             countLowbat();
                          });
                          

                          Hat jemand eine Idee, wo hier der Fehler liegt?

                          Vielen Dank im Voraus!
                          Frank

                          1 Reply Last reply Reply Quote 0
                          • arteck
                            arteck Developer Most Active last edited by arteck

                            @deifel sagte in Skript LOWBAT:

                            at Object.<anonymous>

                            da ist ein Object leer oder das Object hat den unterpunkt nicht bzw. dieser ist null
                            oder du läufts aus der Schleife... wie viele objecte erwartest du

                            D 1 Reply Last reply Reply Quote 0
                            • D
                              deifel @arteck last edited by

                              @arteck said in Skript LOWBAT:

                              @deifel sagte in Skript LOWBAT:

                              at Object.<anonymous>

                              da ist ein Object leer oder das Object hat den unterpunkt nicht bzw. dieser ist null

                              Danke für Deine Hilfe.
                              Kannst Du mir evtl. sagen, wie ich dieses Objekt herausfinde bzw. das Problem beheben kann?

                              arteck 1 Reply Last reply Reply Quote 0
                              • arteck
                                arteck Developer Most Active @deifel last edited by arteck

                                @deifel was kommt den danach

                                LED Bild Pavillion

                                für ein Gerät.. der knallt ja im 84 durchlauf

                                lass dir mal die liste ausgeben

                                var cacheSelectorLOWBAT  = $('channel[state.id=*0.LOWBAT]');
                                log.console('liste->>>>>>>>' + JSON.stringify(cacheSelectorLOWBAT));
                                
                                D 1 Reply Last reply Reply Quote 0
                                • D
                                  deifel @arteck last edited by

                                  @arteck said in Skript LOWBAT:

                                  @deifel was kommt den danach

                                  LED Bild Pavillion

                                  für ein Gerät.. der knallt ja im 84 durchlauf

                                  lass dir mal die liste ausgeben

                                  var cacheSelectorLOWBAT  = $('channel[state.id=*0.LOWBAT]');
                                  log.console('liste->>>>>>>>' + JSON.stringify(cacheSelectorLOWBAT));
                                  

                                  Danke! Und sorry für die Noob-Frage:
                                  Wo baue ich

                                  var cacheSelectorLOWBAT  = $('channel[state.id=*0.LOWBAT]');
                                  log.console('liste->>>>>>>>' + JSON.stringify(cacheSelectorLOWBAT));
                                  
                                  

                                  das ein und was muss ich ergänzen, damit ich ne Liste bekomme? Habs als separates Script und im bestehenden versucht.
                                  Sorry - ich bin nicht so tief in der Materie drin, lerne aber täglich dazu;)

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

                                    @deifel Erstelle ein Test-Skript, das in der Logausgabe die Nummer und ID ausgibt:

                                    $('channel[state.id=*0.LOWBAT]').each(function(id, i) {
                                       if(i > 82) log(i + ': ' + id);
                                    });
                                    
                                    D 1 Reply Last reply Reply Quote 0
                                    • D
                                      deifel @paul53 last edited by

                                      @paul53 said in Skript LOWBAT:

                                      @deifel Erstelle ein Test-Skript, das in der Logausgabe die Nummer und ID ausgibt:

                                      $('channel[state.id=*0.LOWBAT]').each(function(id, i) {
                                         if(i > 82) log(i + ': ' + id);
                                      });
                                      

                                      Hat funktioniert, danke!
                                      Habe jetzt zwar die Seriennummer des Gerätes - aber das Gerät gibt es bei mir gar nicht...!?
                                      Gabs evtl. mal - sprich vermutlich eine Leiche?
                                      Wie bekomme ich das jetzt raus? Finde es weder unter Homematic, noch bei Objekten in IOBroker...

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

                                        Ich habe das Gerät jetzt manuell unter Objekte bei der Funktion "Batteriebetrieb" rausgenommen. Dort stand es drin.
                                        Jetzt läuft das Script durch. Am Schluss erscheinen Warnmeldungen für die CUXD-Geräte, obwohl diese nicht im Gewerk "Batteriebetrieb" sind.
                                        Ist diese Warnmeldung korrekt?

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

                                          @deifel sagte:

                                          obwohl diese nicht im Gewerk "Batteriebetrieb" sind.

                                          Das Gewerk wird in Deinem $Selector gar nicht ausgewertet. Gibt es unter CUxD Datenpunkte mit "LOWBAT" ?

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

                                            Nein, unter meinen 5 CUXD-Geräten gibt es keinen LowBat Datenpunkt.
                                            Warnmeldungen erscheinen aber genau für die 5 Geräte im Log.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            890
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            44
                                            201
                                            39712
                                            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