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.
    • 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
                                  • 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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            917
                                            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