NEWS
Skript LOWBAT
-
Hallo Pix,
ich habe das Scrip geändert. Allerdings scheine ich ezwas falsch gemacht zu haben:
Hier die Anzeige des Log mit Script
Hier nochmal das Script als Code:
/* System Zahl Lichter zählt die Lichter in allen Räumen und meldet die Eingeschalteten namentlich Daten kommen vom Gewerk "Licht" */ createState('zählen_Lichter.anzahlLichter', { def: 0, name: 'Anzahl der vohandenen Lichter', def: 'Anzahl aller Lichter / Dimmer im Gewerk' read: true, write: true, min: 0, type: 'number' }); createState('zählen_Lichter.anzahlLichterAn', { def: 0, name: 'Anzahl eingeschaltete Lichter', def: 'Anzahl aller eingeschalteten Lichter / Dimmer im Gewerk' read: true, write: true, min: 0, type: 'number' }); createState('zählen_Lichter.textLichterAn', { def: "", name: 'Aufzählung eingeschaltete Lichter', def: 'Namen aller eingeschalteten Lichter / Dimmer im Gewerk als Liste' read: true, write: true, type: 'string' }); var cacheSelector = $('channel[state.id=*.STATE](functions=Licht)'); var cacheSelectorState = $('channel[state.id=*.STATE](functions=Licht)'); var cacheSelectorDimmer = $('channel[state.id=*.LEVEL](functions=Licht)'); function countLamps(obj) { // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk Licht auf 0 var anzahlLichterAn = 0; var anzahlLichter = 0; var textLichterAn = []; log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat cacheSelectorState.each(function (id, i) { // Schleife für jedes gefundenen Element *.STATE im Gewerk Licht var status = getState(id).val; // Zustand *.STATE abfragen (jedes Element) var obj = getObject(id); if (status === true) { // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt textLichterAn.push(obj.common.name); // Zu Array hinzufügen } log("Licht Nr. " + i + ": " + getObject(id).common.name + ": " + status); ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status }); cacheSelectorDimmer.each(function (id, i) { // Schleife für jedes gefundenen Element *.LEVEL im Gewerk Licht var status = getState(id).val; // Zustand *.LEVEL abfragen (jedes Element) if (parseFloat(status) > 0) { // Wenn Dimmwert über 0 textLichterAn.push(obj.common.name); // Zu Array hinzufügen } log("Licht Nr. " + i + ": " + id + ": " + status); // gibt alle Elemente *.LEVEL im Gewerk Licht mit dem aktuelle Status im Log aus ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status }); // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben log("Text: " + textLichterAn); log("Anzahl Lichter: " + anzahlLichter + " # davon Lichter an: " + anzahlLichterAn); // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS) setState("zählen_Lichter.textLichterAn", textLichterAn.join(', ')); // Schreibt die aktuelle Namen der eingeschalteten Lichter setState("zählen_Lichter.anzahlLichterAn", textLichterAn.length); // Schreibt die aktuelle Anzahl der eingeschalteten Lichter setState("zählen_Lichter.anzahlLichter", anzahlLichter); // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Licht } cacheSelectorState.on(function(obj) { // bei Zustandänderung *. STATE im Gewerk Fenster countLamps(obj); }); cacheSelectorDimmer.on(function(obj) { // bei Zustandänderung *. LEVEL im Gewerk Licht countLamps(obj); });
Wenn ich das Script starte, legt es keine Datenpunkte an! Villeicht ist das noch wichtig, ich nutze die Java Script Instanz 1
Gruß Sven
-
Am Ende der Zeilen mit
def: '...Lichter'
fehlt das Komma (in allen 3 Objekten) und der Bezeichner muss desc lauten:
desc: '...Lichter',
-
Ok, sieht dann aber so aus:
Also immer noch irgendetwas falsch… Nur was?
Gruß Sven
-
Richtig:
desc: '...Gewerk',
-
Also immer noch irgendetwas falsch… Nur was? `
createState('zählen_Lichter.anzahlLichter', { def: 0, name: 'Anzahl der vohandenen Lichter', desc: 'Anzahl aller Lichter / Dimmer im Gewerk', read: true, write: true, min: 0, type: 'number' }); createState('zählen_Lichter.anzahlLichterAn', { def: 0, name: 'Anzahl eingeschaltete Lichter', desc: 'Anzahl aller eingeschalteten Lichter / Dimmer im Gewerk', read: true, write: true, min: 0, type: 'number' }); createState('zählen_Lichter.textLichterAn', { def: "", name: 'Aufzählung eingeschaltete Lichter', desc: 'Namen aller eingeschalteten Lichter / Dimmer im Gewerk als Liste', read: true, write: true, type: 'string' });
-
Danke Paul,
ich hatte deinen 2 Post leider überlesen. Sorry…
Nun hat das Script keine Fehler mehr. Die Datenpunkte sind auch neu angelegt, aber die Lichter werden nach wie vor nicht gezählt oder eingeschaltete Lampen angezeigt.
Das Log zeigt keinen Fehler mehr.
22:25:46.010 [info] javascript.1 Stop script script.js.Licht 22:25:46.125 [info] javascript.1 Start javascript script.js.Licht 22:25:46.126 [info] javascript.1 script.js.Licht: registered 0 subscriptions and 0 schedules
WAS IST BLOß LOS
Gruß Sven
-
Das Script zählt nur, wenn sich was ändert, also irgendein Licht ein- oder ausgeschaltet wird. Hast du das gemacht ?
-
Ja ich habe mehrfach Lichter ein und ausgeschaltet. Aber es ändert sich nichts.
Gruß Sven
-
Ja ich habe mehrfach Lichter ein und ausgeschaltet. Aber es ändert sich nichts. `
Ich gehe mal davon aus, dass alle Lichtschalt/dimm-Datenpunkte dem Gewerk (enum.functions) "Licht" zugeordnet sind ?Ist die ID der enum evtl. kleingeschrieben (licht) ?
-
Aha, da habe ich etwas neues glaube ich.
Aber wie ändere ich den Funktionsnamen. In der CCU heißt das Gewerk nur Licht…
Gruß Sven
-
Da kann ich nicht weiterhelfen, da ich weder enums noch den Rega-Adapter benutze.
Ich würde versuchen
functions=Licht
gegen
functions=$funcLight
auszutauschen, oder eine neue enum.functions mit dem Namen Licht zu erstellen und alle betreffenden Datenpunkte zuzuordnen.
Wahrscheinlich erhälst Du den richtigen Hinweis von jemandem, der die enum.functions und auch den Rega-Adapter verwendet :?:
-
Danke Paul,
vielleicht kann da ja noch jemand etwas zu sagen…
Gruß Sven
-
Hallo Sven
bennen auf der ccu das Gewerk Licht in was anderes zum old licht und dann wieder in Licht
die CCu zeigt zwar Licht an arbeitet aber intern mit Light
in IoBroker sollte unter Aufzählungen
enum.functions das Gewerk Licht stehen
Gruß Stephan
-
Hallo Stephan,
danke für deinen Tipp. Ich habe das Gewerk umbenannt und die ccu neu gestartet. Dann zurück benannt und nochmal neu gestartet. Und jetzt klappts.
@all danke für eure Hilfe. Es funktioniert. 1000 dank.
Gesendet von iPhone mit Tapatalk
-
Moin,
ich habe im Script ( http://www.iobroker.net/docu/?page_id=2936&lang=de ) in Zeile 42 einfach 120 anstatt 60 eingetragen. Ich will nur alle 2 Std. den Zustand checken. Macht aber weiterhin jede Stunde!?
-
Hallo,
Dann nutze den nächsten Stern (für Stunden).
schedule("* */2 * * *"
Gruß
Pix
EDIT: Fehler in den nächsten Posts erklärt
-
@pix:Hallo,
Dann nutze den nächsten Stern (für Stunden).
schedule("* */2 * * *"
Gruß
Pix `
Nun wird jede Minute getriggert!?cacheSelectorLOWBAT.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken countLowbat(obj); }); schedule("* */2 * * *", function () { //oder!! soll entweder ausgelöst werden alle 10 Minuten log("===>Will be triggered every 2 hours!"); countLowbat(); });
-
-
Sorry, natürlich. :oops: Das kommt, wenn man eben zwischen Tür und Angel antwortet. :twisted:
Der erste Stern steht für jede Minute. Ersetzt man den Stern durch eine Zahl (zwischen 0 und 59), wird zu dieser Minute getriggert. Man kann auch Bereiche und Aufzählungen nutzen.
Wenn man die weiteren Sterne ersetzt, lassen sich noch genauere/speziellere Zeiten definieren
Hier mal die Cron Übersicht von Wikipedia: https://de.wikipedia.org/wiki/Cron
Gruß
Pix
-