NEWS
Skript 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!
-
Hallo,
ich setzte dieses Skript ein, um mich über leere Batterien informieren zu lassen.//Add device rules addDeviceCounter("lowbat_ip", $('channel[state.id=*.LOW_BAT]'), true); addDeviceCounter("lowbat", $('channel[state.id=*.LOWBAT]'), true); addDeviceCounter("sticky_unreach", $('channel[state.id=*.STICKY_UNREACH]'), true); addDeviceCounter("unreach", $('channel[state.id=*.UNREACH]'), true); addDeviceCounter("config_pending", $('channel[state.id=*.CONFIG_PENDING]'), true); //addDeviceCounter("open_windows", $('channel{TYPE=SHUTTER_CONTACT}[state.id=*.STATE]'), true); //addDeviceCounter("on_lights", $('channel{TYPE=DIMMER}[state.id=*.LEVEL]'), function(state){return state>0;}); addDeviceCounter("open_shutters", $('channel{TYPE=BLIND}[state.id=*.LEVEL]'), function(state){return state>0;}); //addDeviceCounter("playing_music", $('channel[state.id=*audio-*.playing]'), true); /****************************************** * Code - do not change anything bellow this line * ******************************************/ function addDeviceCounter(name, selector, val_to_count) { //Total amount of devices found by selector var state_total = 'deviceCounter.' + name + '.total'; createState(state_total, 0); //List of devices that match condition var state_list = 'deviceCounter.' + name + '.list'; createState(state_list, ""); //Number of devices that match condition var state_counter = 'deviceCounter.' + name + '.counter'; createState(state_counter, 0); function countDevs(obj) { var d_count = 0; var d_list = []; selector.each(function (id, i) { var status = getState(id).val; var obj = getObject(id); if ((typeof val_to_count === 'function' && val_to_count(status)) || (typeof val_to_count === 'boolean' && val_to_count == status)) { //Get parent object var parentChannelId = id.slice(id.lastIndexOf(".")); var parentDevicelId = id.split(".").slice(0,-2).join("."); var deviceObject = getObject(parentDevicelId); //remember device name d_list.push(deviceObject.common.name); } ++d_count; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status }); log(name + "(" + d_count + "): " + d_list); setState(state_list, d_list.join(' ')); setState(state_counter, d_list.length); setState(state_total, d_count); } //Re-evaluate when a device status changes selector.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken countDevs(obj); }); //Re-evaluate each hour schedule("*/1 * * * *", countDevs); //Evaluate for the first time countDevs(); }
Ich habe LOWBAT und LOW_BAT (also IP Komponenten) im Einsatz.
Nun wollte ich gerne die beiden States zu einer LOWBAT State zusammenfügen.
Habe es mitaddDeviceCounter("lowbat", $('channel[state.id=*.LOW_BAT]'), true); addDeviceCounter("lowbat", $('channel[state.id=*.LOWBAT]'), true);
versucht, aber statt beide States zusammenzuzählen werden mir bei jedem Timer Event (steht zu Testzwecken auf 1 Min.) mal der eine angezeigt / angesagt und mal der andere.
Gibt es überhaupt eine Möglichkeit beide States in einem LOWBAT anzeigen zu lassen?
Kann mir einer sagen, was ich falsch mache oder anders machen muß?Vielen Dank schon mal für die Hilfe.
Gruß
Xanon -
Hallo,
wo findet man die letzte Version vom Script?
-
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 -
@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 -
@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? -
@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));
-
@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 ichvar 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;) -
@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); });
-
@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... -
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? -
@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" ?