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.
    • L
      Linedancer last edited by

      Jaaaaa,

      mit deinen Änderungen am Script funktioniert es so, wie es soll, Danke dafür.

      Da ich nicht so fit mit Javascript bin hatte ich schon mal angefangen das Thema mit Blockly zu lösen, das beherrsche ich wesentlich besser.

      Um deine Frage noch zu beantworten:

      Der mqtt Adapter liefert 0 und 1 für den Fensterstatus.

      Ich bin immer wieder begeistert von der Hilfsbereitschaft hier im Forum. Klasse.

      1 Reply Last reply Reply Quote 0
      • Q
        quorle last edited by

        Habe heute auch einmal das LOWBAT Script in Angriff genommen, jedoch wird bei mir ( Anscheinlich ) nicht alles so angezeigt wie erwünscht.

        Ich habe einige CuxD Sensoren eingebunden, die auch einen LOWBAT haben, und einige HM-Geräte ( die haben aber zwei States 1. LOWBAT und 2. LOWBAT_ALARM).

        Das Script läuft durch, aber in den States steht folgendes:

        javascript.0.zählenLowbat.anzahlLOWBAT = <u>0</u>

        javascript.0.zählenLowbat.möglicheLOWBAT = <u>steht nichts drin</u>

        javascript.0.zählenLowbat.textLOWBAT = <u>steht auch nichts drin</u>

        <u>Script:</u>

        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("*/1 * * * *", function () {                                  //oder!! soll entweder ausgelöst werden alle 10 Minuten
           log("===>Will be triggered every 60 minutes!"); 
           countLowbat();
        });
        

        <u>Log:</u>

        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: ===>Will be triggered every 60 minutes!
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Ausgelöst bei Timer
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 0: Fensterkontakt 1 Wohnzimmer:0.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 1: HM-Sec-SCo OEQ0705944:1.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 2: Thermostat Fenster Wohnzimmer:0.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 3: Thermostat Wand Wohnzimmer:0.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 4: Thermostat Kinderzimmer 1:0.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 5: Thermostat Flur:0.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 6: Thermostat Kinderzimmer 2:0.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 7: Thermostat Badezimmer:0.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 8: Temperatur Sensor Wohnzimmer:0.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 9: Temperatur Sensor Flur:0.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 10: Temperatur Sensor Kind 1:0.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 11: Temperatur Sensor Badezimmer:0.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 12: Temperatur und Feuchte Sensor Aussen:0.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 13: Temperatur Sensor Kind 2:0.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Geräte Nr. 14: Temperatur Sensor Aussen:0.LOWBAT: false
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Text:
        17:21:00.004	info	javascript.0 script.js.common.System.Alarmmeldungen_Batterien_1: Anzahl Geräte: 0 # davon LOWBAT erkannt: 15
        17:21:01.768	info	javascript.0 Stop script script.js.common.System.Alarmmeldungen_Batterien_1
        

        Kann ir hier jemand helfen?

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

          Bin ebenfalls am LOWBAT und UNREACH Skript dran.

          Doch irgendwie scheint sich bei mir das gleiche Problem eingeschlichen zu haben, wie bei @quorle.

          Bei LOWBAT werden zusätzlich Aktoren von HomeMatic angezeigt, die NICHT mit Batterien betrieben werden.

          Warum dann der Datenpunkt LOWBAT auftaucht ist mir ein Rätsel - weiss jemand von euch weshalb das so ist, oder ob hier was falsch läuft?

          Hier mal meine Skripte die ich verwende für (beide zeigen Daten an -> LOWBAT hat gleiche Anzahl an Geräten wie UNREACH ( :roll: )):

          LOWBAT

          createState('zählenLowbat.möglicheLOWBAT', 0, {type: 'number'});   // wenn benötigt: Anzahl der vorhandenen LOWBAT
          createState('zählenLowbat.anzahlLOWBAT', 0, {type: 'number'});     // wenn benötigt: Anzahl der tatsächlichen LOWBAT
          createState('zählenLowbat.textLOWBAT', " ", {type: 'string'});     // Anzeige der LOWBAT
          
          var cacheSelectorLOWBAT  = $('channel[state.id=*.LOWBAT]');
          var loggen = true;  // = false, wenn kein Logging gewünscht
          
          function countLowbat() {
             // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
             var moeglicheLOWBAT  = 0;
             var anzahlLOWBAT     = 0;
             var textLOWBAT       = [];
             cacheSelectorLOWBAT.each(function (id, i) {   // Schleife für jedes gefundenen Element *.LOWBAT
                //var status = getState(id).val;             // Zustand *.LOWBAT abfragen (jedes Element)
                var status = false;
                    if(getState(id)) {
                       status = getState(id).val; 
                    }
                var obj    = getObject(id);
                if (status) {
                   textLOWBAT.push(obj.common.name);       // Zu Array hinzufügen
                }                
                if(loggen) 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
             if(loggen) log("Text: " + textLOWBAT.join(', '));
             if(loggen) 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(',
          ')); // Schreibt die Namen der Geräte mit LOWBAT Meldung
             setState("zählenLowbat.anzahlLOWBAT",   textLOWBAT.length);        // Schreibt die Anzahl der LOWBAT-Meldungen
             setState("zählenLowbat.möglicheLOWBAT", moeglicheLOWBAT);          // Schreibt die Anzahl der vorhandene Geräte 
          }
          
          cacheSelectorLOWBAT.on(function() {   // bei Zustandänderung *.LOWBAT in allen Gewerken
             countLowbat();
          });
          
          // oder!! soll entweder ausgelöst werden alle 60 Minuten
          schedule("*/60 * * * *", function () {                        
             countLowbat();
          });
          
          

          UNREACH

          createState('zählen_UNREACH.moeglicheUNREACH', 0);   // wenn benötigt: Anzahl der vorhandenen LOWBAT
          createState('zählen_UNREACH.anzahlUNREACH', 0);     // wenn benötigt: Anzahl der vorhandenen LOWBAT
          createState('zählen_UNREACH.textUNREACH', " ");     // Anzahl LOWBAT, die an sind als Variable unter Javascript.0 anlegen
          
          //var cacheSelector = $('channel[state.id=*.UNREACH]');
          
          var cacheSelectorUNREACH  = $('channel[state.id=*.UNREACH]');
          
          function countUNREACH(obj) {
               // Setzt die Zähler vor dem Durchlauf aller Elemente *.UNREACH auf 0
              var moeglicheUNREACH = 0;
              var anzahlUNREACH = 0;
              var textUNREACH = [];
          
             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'); 
             } 
          
             cacheSelectorUNREACH.each(function (id, i) {                          // Schleife für jedes gefundenen Element *.LOWBAT
                  //var status = getState(id).val;                                  // Zustand *.UNREACH abfragen (jedes Element)
                  var state = getState(id);
                  if  ( !state) {
                  console.error('State ' + id + ' does not exist');
                  return;
                  }
                  var status =  state.val;
                  var obj    = getObject(id);
                  if (status === true) {                                          // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                       textUNREACH.push(obj.common.name);                          // Zu Array hinzufügen
                  }                
                  log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                  ++moeglicheUNREACH;                                                 // 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: " + textUNREACH);
                  //log("Anzahl Geräte: " + moeglicheUNREACH + " davon UNREACH erkannt: " +  anzahlUNREACH);
                  log("Anzahl Geräte: " + moeglicheUNREACH + " davon UNREACH erkannt: " +  textUNREACH.length);
          
              // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
             setState("zählen_UNREACH.textUNREACH", textUNREACH.join(',
          '));      // Schreibt die aktuelle Namen der Geräte mit LOWBAT Meldung
             setState("zählen_UNREACH.anzahlUNREACH", textUNREACH.length);           // Schreibt die aktuelle Anzahl der Geräte im System
             setState("zählen_UNREACH.moeglicheUNREACH", moeglicheUNREACH);          // Schreibt die aktuelle Anzahl der vorhandene Geräte 
          }
          
          cacheSelectorUNREACH.on(function(obj) {    // bei Zustandänderung *. UNREACH in allen Gewerken
             countUNREACH(obj);
          });
          schedule("*/60 * * * *", function () {                                                    //oder!! soll entweder ausgelöst werden alle 10 Minuten
             log("===>Will be triggered every 60 minutes - UNREACH!"); 
             countUNREACH();
          });
          
          

          Ich wäre dankbar für Hilfe bzw. Tips zu dem Problem.

          Danke vorab.

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

            @nukleuz:

            Bei LOWBAT werden zusätzlich Aktoren von HomeMatic angezeigt, die NICHT mit Batterien betrieben werden. `
            Welche Version des JS-Adapters ?

            Was ergibt das Log mit

            cacheSelectorLOWBAT.each(function (id, i) {
               log(id);
            });
            

            zusätzlich am Skriptende.

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

              ` > Welche Version des JS-Adapters ?

              Was ergibt das Log mit `

              Version 3.6.4

              und
              9401_ausgabe_lowbat.png

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

                Das sind 27 IDs. Welche sind nicht echt (existieren im Reiter "Objekte" nicht) ?

                Die LOWBAT im Kanal 1 könnten doppelt sein ?

                CUxD-Geräte haben LOWBAT ?

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

                  Es existieren alle Datenpunkte/IDs unter Objekte.

                  Richtig, die LOWBATs sind im Kanal 1 doppelt - warum?

                  Und warum CUxD Geräte LOWBAT haben kann ich auch nicht sagen, nur dass dem so ist in meinen Datenpunkten.

                  Hier mal ein paar Bilder:

                  9401_fensterkontakt_doppelt_lowbat.png

                  9401_cuxd_lowbat.png

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

                    Die gelb markierten dürften auch keinen LOWBAT haben, weil keine Batterien:

                    9401_keine_batterie.png

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

                      Was sind die gelb markierten Geräte ?

                      Wenn sie tatsächlich keine Batterien (LOWBAT) haben, dürfte der Wert auch nie auf true gehen.

                      Den Kanal 1 und die CUxD-Geräte sollte man ausklammern können:

                      var cacheSelectorLOWBAT  = $('hm-rpc.1.*.0.LOWBAT');
                      
                      
                      1 Reply Last reply Reply Quote 0
                      • paul53
                        paul53 last edited by

                        @quorle:

                        Kann ir hier jemand helfen? `
                        Ändere bitte ++anzahlLOWBAT –> ++moeglicheLOWBAT

                              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
                        • nukleuz
                          nukleuz last edited by

                          @paul53:

                          Was sind die gelb markierten Geräte ?

                          Wenn sie tatsächlich keine Batterien (LOWBAT) haben, dürfte der Wert auch nie auf true gehen.

                          Den Kanal 1 und die CUxD-Geräte sollte man ausklammern können:

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

                          Die gelb markierten sind Zwischenstecker und Unterputzaktoren - also definitiv keine Batterien vorhanden 😉

                          Der Code scheint funktioniert zu haben, doch mein Log gibt jetzt alle Einträge dreifach aus :roll:

                          9401_dreifach_log.png

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

                            @nukleuz:

                            mein Log gibt jetzt alle Einträge dreifach aus `
                            Eigenartig 😮 Ändert es sich, wenn es so angegeben wird ?

                            var cacheSelectorLOWBAT  = $('channel[state.id=hm-rpc.1.*.0.LOWBAT]');
                            
                            1 Reply Last reply Reply Quote 0
                            • nukleuz
                              nukleuz last edited by

                              Ja, wie geil - damit funktioniert es wunderbar.

                              Danke für deinen Support! 😄

                              1 Reply Last reply Reply Quote 0
                              • 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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            510
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

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