NEWS
Skript LOWBAT
-
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?
-
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.
-
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.
-
` > Welche Version des JS-Adapters ?
Was ergibt das Log mit `
Version 3.6.4
und
-
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 ?
-
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:
-
Die gelb markierten dürften auch keinen LOWBAT haben, weil keine Batterien:
-
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');
-
Kann ir hier jemand helfen? `
Ändere bitte ++anzahlLOWBAT –> ++moeglicheLOWBATlog("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status); ++moeglicheLOWBAT; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status });
-
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:
-
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]');
-
Ja, wie geil - damit funktioniert es wunderbar.
Danke für deinen Support!
-
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.
-
werden zusätzlich die LOWBAT_ALARM Einträge ausgegeben (also doppelte Anzahl). `
Dann versuche malvar cacheSelectorLOWBAT = $('channel[state.id=hm-rpc.1.*.0.LOWBAT$]');
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. -
Der Versuch hat auch super geklappt und das Löschen versuche ich gleich und gebe Rückinfo.
Danke!
-
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.
-
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 -
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 -
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 });
-
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!