NEWS
Skript LOWBAT
-
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" ?
-
Nein, unter meinen 5 CUXD-Geräten gibt es keinen LowBat Datenpunkt.
Warnmeldungen erscheinen aber genau für die 5 Geräte im Log. -
-
10:30:00.016 warn javascript.0 (28564) at script.js.common.Lowbat:20:10 10:30:00.016 warn javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24) 10:30:00.016 warn javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4) 10:30:00.017 warn javascript.0 (28564) at script.js.common.Lowbat:21:19 10:30:00.017 warn javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24) 10:30:00.017 warn javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4) 10:30:00.018 info javascript.0 (28564) script.js.common.Lowbat: Geräte Nr. 101: undefined: null 10:30:00.018 warn javascript.0 (28564) at script.js.common.Lowbat:20:10 10:30:00.018 warn javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24) 10:30:00.018 warn javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4) 10:30:00.019 warn javascript.0 (28564) at script.js.common.Lowbat:21:19 10:30:00.019 warn javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24) 10:30:00.019 warn javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4) 10:30:00.020 info javascript.0 (28564) script.js.common.Lowbat: Geräte Nr. 102: undefined: null 10:30:00.021 warn javascript.0 (28564) at script.js.common.Lowbat:20:10 10:30:00.021 warn javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24) 10:30:00.021 warn javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4) 10:30:00.022 warn javascript.0 (28564) at script.js.common.Lowbat:21:19 10:30:00.022 warn javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24) 10:30:00.022 warn javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4) 10:30:00.023 info javascript.0 (28564) script.js.common.Lowbat: Geräte Nr. 103: undefined: null 10:30:00.023 warn javascript.0 (28564) at script.js.common.Lowbat:20:10 10:30:00.023 warn javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24) 10:30:00.023 warn javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4) 10:30:00.024 warn javascript.0 (28564) at script.js.common.Lowbat:21:19 10:30:00.024 warn javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24) 10:30:00.024 warn javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4) 10:30:00.024 info javascript.0 (28564) script.js.common.Lowbat: Geräte Nr. 104: undefined: null 10:30:00.025 warn javascript.0 (28564) at script.js.common.Lowbat:20:10 10:30:00.025 warn javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24) 10:30:00.025 warn javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4) 10:30:00.026 warn javascript.0 (28564) at script.js.common.Lowbat:21:19 10:30:00.026 warn javascript.0 (28564) at countLowbat (script.js.common.Lowbat:18:24) 10:30:00.026 warn javascript.0 (28564) at Object.<anonymous> (script.js.common.Lowbat:46:4) 10:30:00.026 info javascript.0 (28564) script.js.common.Lowbat: Geräte Nr. 105: undefined: null 10:30:00.026 info javascript.0 (28564) script.js.common.Lowbat: Text: 10:30:00.026 info javascript.0 (28564) script.js.common.Lowbat: Anzahl Geräte: 106 # davon LOWBAT erkannt: 0
-
@deifel Welche IDs gibt das Test-Skript mit den Nummern 101 bis 105 aus ?
-
@paul53 said in Skript LOWBAT:
$('channel[state.id=*0.LOWBAT]').each(function(id, i) { if(i > 82) log(i + ': ' + id); });
10:35:50.771 info javascript.0 (28564) script.js.common.TEST: 100: hm-rpc.0.QEQ0087728.0.LOWBAT 10:35:50.771 info javascript.0 (28564) script.js.common.TEST: 101: hm-rpc.1.CUX2801001.0.LOWBAT 10:35:50.771 info javascript.0 (28564) script.js.common.TEST: 102: hm-rpc.1.CUX4000001.0.LOWBAT 10:35:50.771 info javascript.0 (28564) script.js.common.TEST: 103: hm-rpc.1.CUX9000002.0.LOWBAT 10:35:50.771 info javascript.0 (28564) script.js.common.TEST: 104: hm-rpc.1.CUX9000003.0.LOWBAT 10:35:50.771 info javascript.0 (28564) script.js.common.TEST: 105: hm-rpc.1.CUX9000004.0.LOWBAT