Funktionen eines Items
Jedes definierte Item bietet die folgenden Methoden an, die unter anderem in eval Ausdrücken und Logiken genutzt werden können.
Funktion |
Beschreibung |
---|---|
autotimer(time, value, compat) |
Setzt einen Timer bei jedem Werte-Wechsel der Items. Angegeben wird die Zeit (time) die vergehen soll, bis das Item auf den Wert (value) gesetzt wird. Die Zeitangabe erfolgt in Sekunden. Eine Angabe der Dauer in Minuten ist wie in ‚10m‘ möglich. Die Bedeutung und Wirkungsweise von compat bitte auf der Seite autotimer nachlesen. |
|
Blendet das Item mit der definierten Schrittweite (int oder float) und timedelta (int oder float in Sekunden) auf einen angegebenen Wert auf oder ab. So wird z.B.: sh.living.light.fade(100, 1, 2.5) das Licht im Wohnzimmer mit einer Schrittweite von 1 und einem Zeitdelta von 2,5 Sekunden auf 100 herunter regeln. Bei manueller Änderung wird der Prozess gestoppt. Dieses Verhalten kann jedoch durch stop_fade oder continue_fade geändert werden. Genaueres dazu ist in den Beispielen unten zu finden. |
remove_timer() |
Entfernen eines vorher mit der Funktion timer() gestarteten Timers ohne dessen Ablauf abzuwarten und die mit dem Ablauf verbundene Aktion auszuführen. |
return_children() |
Liefert die Item-Pfade der direkt untergeordneten Items zurück. Aufruf: for child in sh.item.return_children(): … |
return_parent() |
Liefert den Item-Pfad des übergeordneten Items zurück. Aufruf: sh.item.return_parent() |
timer(time, value, compat) |
Funktioniert wir autotimer(), ausser dass die Aktion nur einmal ausgeführt wird. Die Bedeutung und Wirkungsweise von compat bitte auf der Seite autotimer nachlesen. |
Weiterhin werden die folgenden Funktionen unterstützt, die jedoch ab SmartHomeNG v1.6 nicht mehr genutzt werden sollen. Bitte stattdessen die entsprechenden in SmartHomeNG v1.6 eingeführten Properties benutzen.
Funktion |
Beschreibung |
---|---|
id() |
Liefert den item-Pfad des Items zurück. Aufruf: sh.item.id() |
() |
Liefert den aktuellen Wert des Items zurück. Aufruf: sh.item() |
prev_value() |
Liefert den Wert des Items zurück, den es vor der letzten Änderung hatte. |
last_update() |
Liefert ein datetime Objekt mit dem Zeitpunkt des letzten Updates des Items zurück. Im Gegensatz zu last_change() wird dieser Zeitstempel auch verändert, wenn sich bei einem Update der Wert des Items nicht ändert. |
prev_update() |
Liefert ein datetime Objekt mit dem Zeitpunkt des vorletzten Updates des Items zurück. Im Gegensatz zu prev_change() wird dieser Zeitstempel auch verändert, wenn sich bei einem Update der Wert des Items nicht ändert. |
last_change() |
Liefert ein datetime Objekt mit dem Zeitpunkt der letzten Änderung des Items zurück. |
prev_change() |
Liefert ein datetime Objekt mit dem Zeitpunkt der vorletzten Änderung des Items zurück. |
last_trigger() |
Liefert ein datetime Objekt mit dem Zeitpunkt der letzten eval Triggerung des Items zurück. Hat das Item kein eval Attribut oder wurde es nicht getriggert, wird der Zeitpunkt des letzten Updates übermittelt. (Neu ab SmartHomeNG v1.9.1) |
prev_trigger() |
Liefert ein datetime Objekt mit dem Zeitpunkt der vorletzten eval Triggerung des Items zurück. (Neu ab SmartHomeNG v1.9.1) |
update_age() |
Liefert das Alter des Items seit dem letzten Update in Sekunden zurück. Das Update Age wird auch gesetzt, wenn sich bei einem Update der Wert des Items nicht ändert. (Neu ab SmartHomeNG v1.4) |
prev_update_age() |
Liefert das Alter des vorangegangenen Updates in Sekunden zurück. |
age() |
Liefert das Alter des Items seit der letzten Änderung des Wertes in Sekunden zurück. |
prev_age() |
Liefert das Alter des vorangegangenen geänderten Wertes in Sekunden zurück. |
trigger_age() |
Liefert das Alter der letzten Eval Triggerung in Sekunden zurück. (Neu ab SmartHomeNG v1.9.1) |
prev_trigger_age() |
Liefert das Alter der vorletzten Eval Triggerung in Sekunden zurück. (Neu ab SmartHomeNG v1.9.1) |
changed_by() |
Liefert einen String zurück, der auf das Objekt hinweist, welches das Item zuletzt geändert hat. |
updated_by() |
Liefert einen String zurück, der auf das Objekt hinweist, durch welches das Item zuletzt ein Update erfahren hat. |
triggered_by() |
Liefert einen String zurück, der auf das Objekt hinweist, durch welches eine eventuell vorhandene eval Expression getriggert wurde. (Neu ab SmartHomeNG v1.9.1) |
Beispiele für die Nutzung von Funktionen
Die Funktionen von Items können in Logiken, in eval Ausdrücken (Attribute eval, on_change, on_update) und beim Schreiben von Plugins verwendet werden.
Die folgende Beispiel Logik nutzt einige der oben beschriebenen Funktionen:
# getting the parent of item
sh.item.return_parent()
# get all children for item and log them
for child in sh.item.return_children():
logger.debug( ... )
# set the item after 10 minutes to 42
sh.item.autotimer('10m', 42)
# disable autotimer for item
sh.item.autotimer()
# will in- or decrement the living room light to 100 by a stepping of ``1`` and a timedelta of ``2.5`` seconds.
# As soon as the item living.light gets changed manually, the fader stops.
sh.living.light.fade(100, 1, 2.5)
Die folgenden Beispiele erläutern die fade-Funktion im Detail. stop_fade und continue_fade werden als reguläre Ausdrücke angegeben/verglichen (case insensitive). Beispiel 1: Der Fade-Prozess wird nur gestoppt, wenn ein manueller Item-Wert über das Admin-Interface eingegeben wurde. Wird das Item von einem anderen Caller aktualisiert, wird normal weiter gefadet. Beispiel 2: Der Fade-Prozess wird durch sämtliche manuelle Item-Änderungen gestoppt, außer die Änderung kommt von einem Caller, der „KNX“ beinhaltet. Beispiel 3: Der Fade-Prozess wird bei jeder manuellen Item-Änderung gestoppt. Die erste Wertänderung findet erst nach Ablauf der delta Zeit statt, in dem Fall wird der Wert also (erst) nach 2,5 Sekunden um 1 erhöht/verringert. Beispiel 4: Wird die Fade-Funktion für das gleiche Item erneut mit anderen Werten aufgerufen und der update Parameter ist auf True gesetzt, dann wird das Fading „on the fly“ den neuen Werten angepasst. So könnte während eines Hochfadens durch Setzen eines niedrigeren Wertes der Itemwert direkt abwärts gefadet werden. Auch die anderen Parameter werden für den aktuellen Fade-Vorgang überschrieben/aktualisiert.
# erstes Beispiel sh.living.light.fade(100, 1, 2.5, stop_fade=["admin:*"]) # zweites Beispiel sh.living.light.fade(100, 1, 2.5, continue_fade=["KNX"]) # drittes Beispiel sh.living.light.fade(100, 1, 2.5, instant_set=False) # viertes Beispiel sh.living.light.fade(100, 1, 2.5, update=True) sh.living.light.fade(5, 2, 5.5, update=True)
Der folgende Beispiel eval Ausdruck sorgt dafür, dass ein Item den zugewiesenen Wert nur dann übernimmt, wenn die Wertänderung bzw. das Anstoßen der eval Funktion über das Admin Interface erfolgt ist und das letzte Update vor der aktuellen Triggerung über 10 Sekunden zurück liegt.
eval: value if sh..self.triggered_by().startswith('admin') and sh..self.update_age() > 10 else None