NEWS
Zigbee2mqtt installation
-
@mickym said in Zigbee2mqtt installation:
@schmetterfliege Na auf ms Basis ist schwachsinn - da braucht das System ja schon länger. Ich würde mind. 100ms nehmen. Und die trigger Node ist so intelligent, dass die Mehrfach für jedes topic getrennt reagieren kann.
Stimmt, 1ms is echt n bissl arg wenig
Okay, nice! Hab ich gar nicht dran gedacht dass es diese Option gab! Danke -
@mickym
Ich versuche gerade den Anfang meiner Tabelle wieder in Ordnung zu bringen, und möchte erstmal den Raum rausziehen.
Der Raum ist der vorletzte Wert, das spuckt mir aber die letzten beiden aus.
Wie schneide ich denn den zweiten Teil weg?
Wenn ich das zweite ".*" auch in Klammern mache, ist es das selbe Ergebnis.
Müsste es dann nicht $1 und $2 geben?EDIT: Also auch in der Change Node. Wie das in einer Function Node gehen würde ist klar
-
.*zigbee2mqtt\.(.*)\..*
-
@mickym
Vielen Dank! "hab noch Multisensor" reingepackt und schon gehtsWie nennt sich diese "Syntax" denn? Dann würde ich mich da auch mal einlesen, damit ich auch verstehe wie das mit ".." funktioniert
-
@schmetterfliege Nein das ist keine spezielle Syntax sondern Du musst ja Deine Klammer wieder begrenzen.
(.*)\.
Das bedeutet, dass meine Klammer durch den Punkt begrenzt ist.
.*
Der Rest bedeutet beliebiges Zeichen x mal.
zusammen:
(.*)\..*
Ansonsten hiermit testen und die Codes sind da drin auch erklärt:
In der Explanation wird das dann auch noch mal Stück für Stück hergeleitet.
Also :
.*zigbee2mqtt\.(.*)\..*
Mich interessiert das vorne nicht bis zigbee2mqtt auftaucht, dann ein Punkt, dann beliebige Zeichen, die ich in die Gruppe $1 packe, bis wieder ein Punkt kommt, der aber nicht mehr Bestandteil der Gruppe ist. Der Rest interessiert wieder nicht.
Damit alleine
\.*
sagst Du ja nur das ein Punkt auftauchen kann oder auch nicht - also in dem Fall keine eindeutige Begrenzung der Klammer, die ja mit dem Punkt aufhören MUSS.
-
@mickym
Thanks, die Seite ist echt praktisch!Noch eine Dummi-Frage:
Vorher hatte ich ja den Raum als Wert selbst gespeichert.
Jetzt sind die Sachen im Kontext aber nicht mehr per zigbee-id gespeichert, sondern über den Raum selbst. Nur weiß ich nicht wie ich den Teil adressieren kann?
ist das payload.id?
EDIT: die id ist es schon mal nicht
-
@schmetterfliege Wieso - das eine hat doch mit dem anderen nichts zu tun. Dein Raum ist die Eigenschaft "room" in jedem einzelnen Room Objekt, dass Du in der payload mitgibst. Das was Du oben machst ist ja nur die Definition der Spalten aber nicht das Array der Objekte die Du übergibst?
-
Ich befürchte die Antwort wird sein dass ich den Raum speichern muss^^
Kann ich denn irgendwie die "topic" jedes Objektes in die Objekte packen, ohne das separat im Objekt abzuspeichern?
-
@schmetterfliege Richtig - Du musst in jedem Objekt eine Eigenschaft "room" haben, damit diese der entsprechenden Spalte zugeordnet werden kann.
-
@mickym said in Zigbee2mqtt installation:
@schmetterfliege Richtig - Du musst in jedem Objekt eine Eigenschaft "room" haben, damit diese der entsprechenden Spalte zugeordnet werden kann.
Okay, also die Objekte werden ohne deren Topic übergeben. Hmm.
-
@schmetterfliege Du brauchst doch das Topic nur in die einzelnen Objekte mit aufnehmen. Also bevor Du es zum Array zusammenfasst.Sprich Du hast doch für einen Sensor
ein topic und ein payload Objekt mit Temp., Humidity etc.
Nach dem Du das topic nun extrahiert hast, kannst Du entweder das topic direkt da rein schieben wenn du es nicht mehr brauchst.
Veschiebe msg.topic => msg.payload.room
-
@mickym said in Zigbee2mqtt installation:
@schmetterfliege Du brauchst doch das Topic nur in die einzelnen Objekte mit aufnehmen. Also bevor Du es zum Array zusammenfasst.Sprich Du hast doch für einen Sensor
ein topic und ein payload Objekt mit Temp., Humidity etc.
Nach dem Du das topic nun extrahiert hast, kannst Du entweder das topic direkt da rein schieben wenn du es nicht mehr brauchst.
Veschiebe msg.topic => msg.payload.room
Funktioniert, aber ist das "gut" gelöst so? -
Also wahrscheinlich ist da eigentlich gar kein Unterschied zu vorher und ich hätte das vorher auch so kompakt machen können, aber das is schon geil irgendwie.
Die JSON sind schon ne geile Sache! -
@schmetterfliege Hmm warum nicht - ich hab das nicht mehr alles im Kopf - aber in dem Fall passt es doch ggf. kann man das halt schon vorher - also bevor man das Array aufsplittet schon in s Objekt aufnehmen. Aber egal
-
@schmetterfliege sagte in Zigbee2mqtt installation:
Also wahrscheinlich ist da eigentlich gar kein Unterschied zu vorher und ich hätte das vorher auch so kompakt machen können, aber das is schon geil irgendwie.
Die JSON sind schon ne geile Sache!Ja leider erkennen nur die wenigsten, wie fantastisch JSON ist - die meisten beschäftigen sich halt nicht damit.
-
@mickym said in Zigbee2mqtt installation:
@schmetterfliege Hmm warum nicht - ich hab das nicht mehr alles im Kopf - aber in dem Fall passt es doch ggf. kann man das halt schon vorher - also bevor man das Array aufsplittet schon in s Objekt aufnehmen. Aber egal
Hmm, wüsste ich jetzt tatsächlich nicht wo ich das vorher machen könnte, ohne es in den Kontext zu packen.
Vor dem Split werden ja die Objekte aus dem Kontext geladen, d.h. das muss ich splitten um den Raum dann den einzelnen Objekten hinzufügen zu können.
Klar könnte ich vorher in der Function node machen wo ich auch die anderen Sachen in den Kontext packe, aber das wäre ja dann irgendwie redundant. (Weil Objekt = Raum, und dann wäre da nochmal ein zusätzlich Wert "Raum")
So wie jetzt landet der Raum nicht im Kontext sondern wird nur der Tabelle übergeben. -
@schmetterfliege sagte in Zigbee2mqtt installation:
Vor dem Split werden ja die Objekte aus dem Kontext geladen, d.h. das muss ich splitten um den Raum dann den einzelnen Objekten hinzufügen zu können.
Verstehe ich nicht. Auch, wenn Du über Wildcards rein holst, bekommst Du doch eine Nachricht für einen Sensor mit einem Topic, bevor Du es in einem Array sammelst. Ist auch Käse, dass Du das Objekt rein holst und nicht nur den Wert. In diesem Fall brauchst ja nur den Value, da Du keine Objekteigenschaften brauchst, wie es noch mit dem zigbee-Adapter erforderlich war.
-
Ich hoffe das wird jetzt nicht viiiel zu kompliziert was ich hier von mir gebe, muss aber glaube ich etwas ausholen zum Verständnis:
Der erste Kasten ist das Updaten der Tabelle.
Der zweite Kasten ist hinfällig, da hatte ich den Raum im Kontext gespeichert. Kommt weg, weil ist ja oben mit drin.
Der dritte Kasten ist das "initialisieren" der Tabelle, also der erste Aufbau nach einem Neustart.
Im Dritten hatte ich daher alle Zigbee Daten geholt, im Kontext gespeichert und die Tabelle anhand des Kontext aufgebaut.
Den dritten Teil kann ich ja prinzipiell jetzt genau so easy wie den ersten machen.Den Raum möchte ich ja nicht im Kontext speichern, weil der schon drin steht (die Objekte sind als Raum gespeichert, nicht mehr als zigbee-id). Deshalb kann ich den Raum auch erst nach dem Array in die Tabelle einfügen, weil ich dafür die Objekte aus dem Kontext brauche.
Fällt natürlich weg wenn ich den Raum vorher im Kontext speichere, das ist absolut klar. Aber wären halt redundante Daten :S -
@schmetterfliege Ich bin jetzt wieder mal zu faul - auch wenn ich Deinen Flow schon x Mal durchdacht habe - habe ich ja damals mit gearbeitet, aber:
- Du brauchst keine Prüfung auf irgendwelche IDs?
- Du brauchst keine Liste von Räumen
- Auch Gerätenamen halte ich für überflüssig - da der doch auch Bestandteil des topics ist.
Also die ganzen Topic Objekte zum extrahieren von diesen Informationen ist doch alles im topic enthalten. Und nochmal Du brauchst keine Objekte mehr auszulesen. Was willst Du denn initialisieren - über die Objekte musst Du ja auch nicht mehr Werte aus anderen Datenpunkten auslesen. Das ist doch gerade der Vorteil der Objekte.
Du kannst das ja alles behalten - aber ich würde den Flow neu aufbauen.
-
@mickym said in Zigbee2mqtt installation:
@schmetterfliege Ich bin jetzt wieder mal zu faul - auch wenn ich Deinen Flow schon x Mal durchdacht habe - habe ich ja damals mit gearbeitet, aber:
Bin grad ein wenig überfordert das zu kapieren^^
- Du brauchst keine Prüfung auf irgendwelche IDs?
Wie meinst das? IDs prüfe ich doch gar nicht? Glaube ich^^
- Du brauchst keine Liste von Räumen
Eine Liste von Räumen habe ich auch nicht mehr - den Raum ziehe ich mir ja aus der Topic jedes Objektes (im Flow-Kontext)
- Auch Gerätenamen halte ich für überflüssig - da der doch auch Bestandteil des topics ist.
Gerätenamen habe ich doch gar keine drin? In der Tabelle steht: Raum - Ort (falls es mehr als 1 im Raum gibt) - Temp - Humidity - Last Update
Also die ganzen Topic Objekte zum extrahieren von diesen Informationen ist doch alles im topic enthalten. Und nochmal Du brauchst keine Objekte mehr auszulesen. Was willst Du denn initialisieren - über die Objekte musst Du ja auch nicht mehr Werte aus anderen Datenpunkten auslesen. Das ist doch gerade der Vorteil der Objekte.
Du kannst das ja alles behalten - aber ich würde den Flow neu aufbauen.
Wieso muss ich keine Objekte auslesen? Den Teil verstehe ich nicht.
Ich bekomme vom IoB doch immer ganze Objekte, ich hole die Werte ja gar nicht mehr einzeln ausm IoB sondern nur das JSON.
Also ich glaube ich mache ja genau das was du da sagst^^
In meinem großen Screenshot mit den 3 Kästen: ich habe bisher nur den ersten angepasst. 2. und 3. sind noch alt, der zweite fällt komplett weg und der dritte wird genau so komprimiert wie der erste