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.
    • N
      noxx last edited by

      weiß ich noch nicht….

      08:57:45.984	[info]	javascript.0 Start javascript script.js.common.Batteriestatus
      08:57:45.985	[info]	javascript.0 script.js.common.Batteriestatus: registered 4 subscriptions and 1 schedule
      09:00:01.013	[info]	javascript.0 script.js.common.Batteriestatus: ===>Will be triggered every 60 minutes!
      09:00:01.015	[info]	javascript.0 script.js.common.Batteriestatus: Ausgelöst bei Timer
      09:00:01.015	[info]	javascript.0 script.js.common.Batteriestatus: Geräte Nr. 0: Cresta_ 1 Low battery: false
      09:00:01.016	[info]	javascript.0 script.js.common.Batteriestatus: Geräte Nr. 1: Cresta_ 2 Low battery: false
      09:00:01.016	[info]	javascript.0 script.js.common.Batteriestatus: Geräte Nr. 2: Cresta_ 4 Low battery: false
      09:00:01.016	[info]	javascript.0 script.js.common.Batteriestatus: Geräte Nr. 3: Cresta_ 5 Low battery: false
      09:00:01.017	[info]	javascript.0 script.js.common.Batteriestatus: Text:
      09:00:01.017	[info]	javascript.0 script.js.common.Batteriestatus: Anzahl Geräte: 0 # davon LOWBAT erkannt: 4
      

      Wie binde ich denn zb eine Benachrichtigung per pushover ein, wenn eine Batterie leer ist?

      EDIT

      Mich verwirren die letzten beiden LOG Zeilen

      09:00:01.017   [info]   javascript.0 script.js.common.Batteriestatus: Text:
      09:00:01.017   [info]   javascript.0 script.js.common.Batteriestatus: Anzahl Geräte: 0 # davon LOWBAT erkannt: 4
      

      Zeile 1 ist nach "Text:" leer

      Zeile 2 hätte ich jetzt eher "Anzahl Geräte: 4" und "LOWBAT erkannt: 0" erwartet. Also 4 Geräte gefunden und keine Batterie leer.

      1 Reply Last reply Reply Quote 0
      • T
        tempestas last edited by

        @noxx:

        Mich verwirren die letzten beiden LOG Zeilen

        09:00:01.017   [info]   javascript.0 script.js.common.Batteriestatus: Text:
        09:00:01.017   [info]   javascript.0 script.js.common.Batteriestatus: Anzahl Geräte: 0 # davon LOWBAT erkannt: 4
        

        Zeile 1 ist nach "Text:" leer

        Zeile 2 hätte ich jetzt eher "Anzahl Geräte: 4" und "LOWBAT erkannt: 0" erwartet. Also 4 Geräte gefunden und keine Batterie leer. `

        Hallo noxx,

        schau mal 6 Beiträge weiter oben. Dort habe ich genau das angemerkt und korrigiert. Ist ein Dreher im Skript von der Homepage.

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

          @tempestas:

          Ist ein Dreher im Skript von der Homepage. `
          Stimmt, war einer meiner ersten Versuche in Javascript. Hier die Korrektur:

          ! ````
          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 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);
          ++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.join(', '));
          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 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
          countLowbat();
          });

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

            ist zwar trivial, aber auf Zeile 29 fehlt ein ")"

               log("Text: " + textLOWBAT.join(', '));
            
            1 Reply Last reply Reply Quote 0
            • paul53
              paul53 last edited by

              @starfish:

              auf Zeile 29 fehlt ein ") `
              Danke, ist korrigiert.

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

                bekomme teilweise paar fehler:

                javascript.0	2017-10-07 11:00:00.731	error	at script.js.User.Homematic.Batterie_Check:24:51
                javascript.0	2017-10-07 11:00:00.731	error	Error in callback: TypeError: Cannot read property 'common' of null
                javascript.0	2017-10-07 11:00:00.730	warn	Object "hm-rpc.3.NEQ0000566.0.LOWBAT" does not exist
                javascript.0	2017-10-07 11:00:00.730	warn	Object "hm-rpc.3.NEQ0000566.0.LOWBAT" does not exist
                javascript.0	2017-10-07 11:00:00.730	warn	at script.js.User.Homematic.Batterie_Check:19:20
                javascript.0	2017-10-07 11:00:00.729	warn	State "hm-rpc.3.NEQ0000566.0.LOWBAT" not found
                javascript.0	2017-10-07 11:00:00.729	info	script.js.User.Homematic.Batterie_Check: Geräte Nr. 35: undefined: null
                javascript.0	2017-10-07 11:00:00.729	warn	at script.js.User.Homematic.Batterie_Check:19:20
                javascript.0	2017-10-07 11:00:00.729	warn	State "hm-rpc.2.OEQ0181147.0.LOWBAT" not found
                
                1 Reply Last reply Reply Quote 0
                • T
                  tempestas last edited by

                  Sind das homematic Ip Geräte?

                  Die haben als Datenpunkt Low_Bat nicht Lowbat.

                  Steht hier imho auch schon im thread in einem meiner Postings

                  Edit:

                  Jup, eine Seite weiter vorne… War nicht schwer zu finden

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

                    ein fertiges Script gibt es aber noch nicht?

                    Das sind ja nur die Warnungen

                    Der Error kommt von dem CuxD Gerät

                    1 Reply Last reply Reply Quote 0
                    • T
                      tempestas last edited by

                      Was steht denn in Zeile 24 bei dir im Skript.

                      Zum Thema "ein fertiges Skript gibts nicht?":

                      doch, hier im Thread. Für Homematic IP einfach ergänzen, wie es auf der Vorseite dargestellt ist

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

                                 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
                           }); 
                        

                        24 in der Mitte.

                        ich wusste gestern nicht wo hin mit der ergänzung

                        hier das angepasste script weiß aber nicht ob das richtig ist und das mit der on änderung weiß ich nicht wie.

                        ! ````
                        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 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);
                        ++moeglicheLOWBAT; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                        });
                        cacheSelectorLOW_BAT.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOW_BAT, Homematic IP
                        var status = getState(id).val; // Zustand *.LOW_BAT 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);
                        ++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.join(', '));
                        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 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
                        countLowbat();
                        });

                        1 Reply Last reply Reply Quote 0
                        • T
                          tempestas last edited by

                          Also bei mir heißen CUXD nicht z.B. NEQ….. oder OEQ..

                          das sollten schon "echte" HM Geräte sein imho

                          ! ````
                          createState('zählenLowbat.möglicheLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen Geräte
                          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]');
                          var cacheSelectorLOW_BAT = $('channel[state.id=
                          .LOW_BAT]'); // für Homematic IP, dort LOWBAT in LOW_BAT umbenannt
                          ! 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);
                          ++moeglicheLOWBAT; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                          });
                          ! cacheSelectorLOW_BAT.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOW_BAT, Homematic IP
                          var status = getState(id).val; // Zustand *.LOW_BAT 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);
                          ++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: " + 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);
                          });
                          ! cacheSelectorLOW_BAT.on(function(obj) { // bei Zustandänderung *. LOW_BAT in allen Gewerken
                          countLowbat(obj);
                          });
                          ! schedule("0 */6 * * *", function () { //ausgelöst alle 6 Stunden
                          countLowbat();
                          });

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

                            Die Variable anzahlLOWBAT wird nicht aktualisiert. Ersetze sie bitte durch textLOWBAT.length.

                               log("Anzahl Geräte: " + moeglicheLOWBAT + " # davon LOWBAT erkannt: " +  textLOWBAT.length);
                            
                            
                            1 Reply Last reply Reply Quote 0
                            • T
                              tempestas last edited by

                              stimmt, dürfte aber nur fürs Log relevant sein. Die state wird ja direkt durch .length gesetzt

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

                                Anfängerfrage:

                                Was müsste ich Script angepasst werden, falls dies ohne CCU2 etc. läuft?

                                (Siehe meinen anderen Thread: http://forum.iobroker.net/viewtopic.php … 40#p107442)

                                (Dito für Lichter, Fenster sowie Lowbat)

                                Vielen Dank für eure Hilfe im Voraus.

                                1 Reply Last reply Reply Quote 0
                                • T
                                  tempestas last edited by

                                  Das Skript läuft immer ohne CCU2.

                                  Die Frage ist ja: mit welchem "Hub" sind denn deine Komponenten in iobroker eingebunden? Wenn du homematic Komponenten hast, brauchst du ja entweder ne CCU2 oder nen Raspi als Ersatz. So oder so, eins von beiden muss Daten liefern.

                                  ich sehe gerade im anderen Thread, dass du ja mihome Dinger nutzt. Offenbar gibt es da keinen low_bat oder LOWBAT state sondern percent und voltage.

                                  D.h. du müsstest selber festlegen, aber welchem Prozentsatz (oder welcher Voltzahl, Prozent dürfte einfacher sein, da du dann nicht je nahc Batterieart noch unterscheiden musst) du "virtuell" dein lowbat festlegst.

                                  Ich sehe auch, dass du deine Komponentem einem Gewerk "Lowbat" zugeordnet hast. Das hilft hier nicht. Das (noch anzupassende) Skript soll über alle deine Kontakte einfach nach Percent suchen und ab der gewünschten Schwelle entsprechend "Alarm" geben.

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

                                    Hallo tempestas

                                    Leider funktionieren die Skripte bei mir weder für Lowbat, noch für Fenster oder Licht.

                                    Finde den Fehler leider nicht 😞

                                    Das mit den Prozent ist mir bewusst, habe es auch entsprechend angepasst.

                                    Ev. noch Tipps woran das liegen kann?

                                    (Raspi ist im Einsatz)

                                    1 Reply Last reply Reply Quote 0
                                    • T
                                      tempestas last edited by

                                      Hallo Dalie,

                                      ich glaube, da missverstehst du das Skript.

                                      Deine Komponenten haben einfach den Datenpunkt nicht, den das Skript hier überwacht. Was du getan hast, ist deine Komponenten dem GEWERK "LOWBAT" zuzuordnen. Das ist nicht nötig und bringt auch nichts, denn das heißt nichts anderes, als dass diese Komponenten nun quasi zur Gruppe "LOWBAT" gehören. Genau so gut hättest du die Gruppe auch "Klaus-Bärbel" nennen können.

                                      Diese Zeile

                                      var cacheSelectorLOWBAT  = $('channel[state.id=*.LOWBAT]');
                                      
                                      

                                      ist quasi das Kernstück des Skripts. Es durchsucht alle States (Zustände), die auf .LOWBAT enden. Das gibt es bei normalen Homematic Komponenten. Bei Homematic IP ist es .LOW_BAT. Diese werfen jeweils true oder false aus. Das Skript zählt dann die Anzahl der "true" Zustände.

                                      Genau diesen Zustand gibt es bei deinen Komponenten nicht. Daher hatte ich gesagt, müsste man das bei dir erstmal künstlich nachbauen.

                                      Nur hier im Forum getippt und daher wahrscheinlich noch nicht funktionsfähig, aber probier es mal aus:

                                      ! ````
                                      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 minlevel = 87; // HIER LEGT DU DEINE SCHWELLE FEST. ICH HABE DIE 87% WILLKÜRLICH GEWÄHLT, denn damit sollte beim Test mindestens einmal "lowbat".rauskommen
                                      ! var cacheSelectorLOWBAT = $('channel[state.id=*.percent]'); // HIER HABE ICH NUN AUF DEIEN PROZENT WERT VERWIESEN
                                      ! function countLowbat(obj) {
                                      // Setzt die Zähler vor dem Durchlauf aller Elemente auf 0
                                      var moeglicheLOWBAT = 0;
                                      var textLOWBAT = [];
                                      var lowbattery = false; // NEU EINGEFÜGT
                                      ! 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 value = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)

                                        if(value < minlevel){lowbattery = true} else {lowbattery = false}			// NEU EINGEFÜGT. Ist der Ladestand kleiner als der Schwellwert? Wenn ja, setze die Variable lowbattery auf true
                                      
                                        var obj    = getObject(id);
                                        if (lowbattery=== true) {                                          // wenn Zustand der Variable "lowbattery" = 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 + ": " + lowbattery);
                                        ++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.join(', '));
                                      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 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
                                      countLowbat();
                                      });
                                      ! // Bei Start:
                                      ! countLowbat();
                                      ! ````

                                      1 Reply Last reply Reply Quote 0
                                      • T
                                        tempestas last edited by

                                        Hallo Dali,

                                        ich antworte hier, damit ggf. auch andere etwas davon haben.

                                        Mein Fehler:

                                        var lowbattery = false;
                                        
                                        

                                        wie du schon erkannt hast ist richtig.

                                        Die 87% hatte ich gewählt, weil laut einem Screenshot ein Kontakt nur 86.5% hatte, daher war die Idee, so mindestens einen Kontakt als "lowbat" zu finden.

                                        Den Status "lowbattery" siehst du gar nicht, weil esn ur eine Variable ist, die nicht in die Objects geschrieben wird.

                                        Nun wird ja schonmal gezählt.

                                        Warum er aber keinen lowbat auswirft, müssen wir nun rausfinden.

                                        Dazu bauen wir mal ein logging ein

                                        schreib mal unter diesen Bereich

                                           cacheSelectorLOWBAT.each(function (id, i) {                         // Schleife für jedes gefundenen Element *.LOWBAT
                                              var value = getState(id).val;                                  // Zustand *.LOWBAT abfragen (jedes Element)
                                        
                                        

                                        noch diese Zeile mit rein

                                        log("Wert ist "+value);
                                        
                                        

                                        außerdem muss bitte dieses noch angepasst werden:

                                              if(value < minlevel){lowbattery = true}         // NEU EINGEFÜGT. Ist der Ladestand kleiner als der Schwellwert? Wenn ja, setze die Variable lowbattery auf true
                                        

                                        da standen auch die drei === , das funktioniert nicht.

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

                                          herzlichen Dank! Habe es sofort angepasst.

                                          jedoch ist immer noch auf "false" aber zählen tut er es jedenfalls schon mal! 🙂
                                          4746_x3.jpg

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

                                            Ergänzung:

                                            Hier noch der Log, theoretisch müssten einige Meldungen kommen.
                                            4746_x4.jpg

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            717
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

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