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.
    • 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
                                • paul53
                                  paul53 @deifel last edited by

                                  @deifel sagte:

                                  Warnmeldungen erscheinen

                                  Welche ?

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

                                    10:30:00.016	warn	javascript.0 (28564) at script.js.common.Lowbat:20:10
                                    10:30:00.016	warn	javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24)
                                    10:30:00.016	warn	javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4)
                                    10:30:00.017	warn	javascript.0 (28564) at script.js.common.Lowbat:21:19
                                    10:30:00.017	warn	javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24)
                                    10:30:00.017	warn	javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4)
                                    10:30:00.018	info	javascript.0 (28564) script.js.common.Lowbat: Geräte Nr. 101: undefined: null
                                    10:30:00.018	warn	javascript.0 (28564) at script.js.common.Lowbat:20:10
                                    10:30:00.018	warn	javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24)
                                    10:30:00.018	warn	javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4)
                                    10:30:00.019	warn	javascript.0 (28564) at script.js.common.Lowbat:21:19
                                    10:30:00.019	warn	javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24)
                                    10:30:00.019	warn	javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4)
                                    10:30:00.020	info	javascript.0 (28564) script.js.common.Lowbat: Geräte Nr. 102: undefined: null
                                    10:30:00.021	warn	javascript.0 (28564) at script.js.common.Lowbat:20:10
                                    10:30:00.021	warn	javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24)
                                    10:30:00.021	warn	javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4)
                                    10:30:00.022	warn	javascript.0 (28564) at script.js.common.Lowbat:21:19
                                    10:30:00.022	warn	javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24)
                                    10:30:00.022	warn	javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4)
                                    10:30:00.023	info	javascript.0 (28564) script.js.common.Lowbat: Geräte Nr. 103: undefined: null
                                    10:30:00.023	warn	javascript.0 (28564) at script.js.common.Lowbat:20:10
                                    10:30:00.023	warn	javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24)
                                    10:30:00.023	warn	javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4)
                                    10:30:00.024	warn	javascript.0 (28564) at script.js.common.Lowbat:21:19
                                    10:30:00.024	warn	javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24)
                                    10:30:00.024	warn	javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4)
                                    10:30:00.024	info	javascript.0 (28564) script.js.common.Lowbat: Geräte Nr. 104: undefined: null
                                    10:30:00.025	warn	javascript.0 (28564) at script.js.common.Lowbat:20:10
                                    10:30:00.025	warn	javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24)
                                    10:30:00.025	warn	javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4)
                                    10:30:00.026	warn	javascript.0 (28564) at script.js.common.Lowbat:21:19
                                    10:30:00.026	warn	javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24)
                                    10:30:00.026	warn	javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4)
                                    10:30:00.026	info	javascript.0 (28564) script.js.common.Lowbat: Geräte Nr. 105: undefined: null
                                    10:30:00.026	info	javascript.0 (28564) script.js.common.Lowbat: Text:
                                    10:30:00.026	info	javascript.0 (28564) script.js.common.Lowbat: Anzahl Geräte: 106 # davon LOWBAT erkannt: 0
                                    
                                    paul53 1 Reply Last reply Reply Quote 0
                                    • paul53
                                      paul53 @deifel last edited by

                                      @deifel Welche IDs gibt das Test-Skript mit den Nummern 101 bis 105 aus ?

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

                                        @paul53 said in Skript LOWBAT:

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

                                        10:35:50.771	info	javascript.0 (28564) script.js.common.TEST: 100: hm-rpc.0.QEQ0087728.0.LOWBAT
                                        10:35:50.771	info	javascript.0 (28564) script.js.common.TEST: 101: hm-rpc.1.CUX2801001.0.LOWBAT
                                        10:35:50.771	info	javascript.0 (28564) script.js.common.TEST: 102: hm-rpc.1.CUX4000001.0.LOWBAT
                                        10:35:50.771	info	javascript.0 (28564) script.js.common.TEST: 103: hm-rpc.1.CUX9000002.0.LOWBAT
                                        10:35:50.771	info	javascript.0 (28564) script.js.common.TEST: 104: hm-rpc.1.CUX9000003.0.LOWBAT
                                        10:35:50.771	info	javascript.0 (28564) script.js.common.TEST: 105: hm-rpc.1.CUX9000004.0.LOWBAT
                                        
                                        paul53 1 Reply Last reply Reply Quote 0
                                        • D
                                          deifel last edited by

                                          Hab die Datenpunkte gefunden. Indicator.lowbat heißen die.
                                          Soll / muss ich die entfernen?

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

                                            @deifel Erweitere mal den $Selector:

                                            $('channel[state.id=hm-rpc.0*0.LOWBAT]').each(function(id, i) {
                                               if(i > 82) log(i + ': ' + id);
                                            });
                                            
                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            919
                                            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