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

                                        Damit bekomme ich die CUXD-Geräte nicht mehr angezeigt, nur die "korrekten" Geräte.

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

                                          @deifel Dann übernehme die Erweiterung in das Lowbat-Skript.

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

                                            Ich danke Dir! Wenn ich das so übernehme, dann fehlen mir leider die Geräte aus der HM-IP-Instanz 😕

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            924
                                            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