NEWS
Node-Red Filter
-
War noch ein Fehler bei mir drin. - Sorry
So diese Change Node ersetzt deine Function Node und filtert die -100 raus.
Hier nochmal frisch zum Import
-
@ranzen sagte in Node-Red Filter:
Ja hier habe ich nur das Ausfiltern bedacht und nicht, wenn die Temperatur nicht -100 ist.
Die JSONATA Regel muss also so aussehen:
payload.temperature = -100 ? payload~>|$|{},"temperature"| : payload
-
Ok, habe die Regel geändert.
Ich muss jetzt ein paar Minuten warten, bis die nächsten Datenpakete kommen. LoRaWAN ist da auf 15 Min. eingestellt. -
Perfekt. So passt alles.
Vielen Dank für Deine Hilfe. In Zukunft kann ich mir das tägliche Editieren in der DB sparen.
Dieser Wert "-100" kommt von einem Sensor, der den Saftfluß in einem Apfelbaum misst.
-
@ranzen Hast du jetzt die Change Node mit den 2 Regeln importiert und die vorhandene abgeändert?
In der Node mit den 2 Regeln habe ich nur die beiden Change Nodes in eine zusammengefasst.
-
@mickym Ich kann Dir gerade nicht ganz folgen. Ich habe eben lediglich die letzte JSONATA Regel von Dir eingepflegt.
Ich hatte sie mir nicht genau angeschaut und bin einfach davon ausgegangen, dass sie alle Temperaturdaten durchlässt und nur den Wert "-100" raus filtert.
-
@ranzen sagte in Node-Red Filter:
@mickym Ich kann Dir gerade nicht ganz folgen. Ich habe eben lediglich die letzte JSONATA Regel von Dir eingepflegt.
Ich hatte sie mir nicht genau angeschaut und bin einfach davon ausgegangen, dass sie alle Temperaturdaten durchlässt und nur den Wert "-100" raus filtert.
Na OK - ich hatte Dir halt beide Regeln in eine Change Node hier zusammengefasst: https://forum.iobroker.net/post/1162085
Aber wenn Du zufrieden bist, dann lassen wir es erst mal gut sein.
-
Hier mal ein Blick in die DB. Da stehen in den letzten beiden Zeilen sowohl die Werte nach der Funktion, aber noch vor Deiner Regel als auch nach Deiner Regel.
Und die Zeilen sind identisch.
Also im Moment werden alle richtigen Werte durchgelasseb und in die DB geschrieben. Ob allerdings -100 rausgefiltert wird, weiss ich jetzt noch nicht. Da muss ich warten, bis der Sensor wieder diesen Wert schickt. Das ist total unregelmäßig.
-
2024-05-23T15:37:22.658452338Z 3.378 7.081 1 24.200000000000003 0 2024-05-23T15:37:22.660494064Z 3.378 7.081 1 24.200000000000003 0
-
Nur der Zeitstempel unterscheidet sich um ein paar Millisekunden oder so.
-
@ranzen Ich weiß zwar nicht was Du vergleichst, aber ich hoffe Du kannst mit den 2ms Zeitdifferenz leben. Sonst brauchst du wahrscheinlich einen Hochleistungsrechner. Ansonsten kann man über die InfluxDB Nodes auch bis auf Nanosekunden, den Zeitpunkt festlegen. Der wird in der Influx nur dann automatisch hinzugefügt, wenn man keinen Zeitstempel angibt.
-
@mickym Die erste Regel mit dem msg. payload.uplink_message.decoded_payload wird nicht akzeptiert. Da steht ein rotes Dreieck.
-
-
@ranzen sagte in Node-Red Filter:
@mickym Die erste Regel mit dem msg. payload.uplink_message.decoded_payload wird nicht akzeptiert. Da steht ein rotes Dreieck.
Hast Du den Flow importiert?
Ich konnte den problemlos importieren. Und Du solltest die Change Node ANSTELLE Deiner function Node nehmen und nicht hinter Deine function Node.
-
@mickym Anstelle ? Ok.
-
Habe ich auch gemacht. Gerade noch mal überprüft.
-
So sieht es jetzt aus:
-
@ranzen Ich verstehs nicht-Wenn das Objekt das ist was ich unten geschrieben habe,
Also das hier aus Deine mqtt Node rauskommt.
Dann füge direkt die ChangeNode mit den 2 Regeln dahinter.
So und das funktioniert auch, wie Du siehst, wenn die temperatur -100 ist:
-
@ranzen sagte in Node-Red Filter:
So sieht es jetzt aus:
Na das ist doch nur eine Change NOde mit EINER Regel - beide Regeln.
Diese Change Node hier zum IMPORT:
[{"id":"69bdba3e138433d4","type":"change","z":"289f539dcc33814e","name":"","rules":[{"t":"set","p":"payload","pt":"msg","to":"payload.uplink_message.decoded_payload","tot":"msg"},{"t":"set","p":"payload","pt":"msg","to":"payload.temperature = -100 ? payload~>|$|{},\"temperature\"| : payload","tot":"jsonata"}],"action":"","property":"","from":"","to":"","reg":false,"x":550,"y":6580,"wires":[["9a4ef5f62cf3ee3c"]]}]
hinter deine mqtt Node. Da steht dann change: 2 Regeln und nicht setze msg.payload
-
@mickym Ich hatte immer direkt die Regel angepasst. Jetzt habe ich aber trotzdem noch einmal einen IMPORT gemacht.
Wie gesagt: wann der Wert -100 kommt, weiss ich nicht. Aber sicher ist , dass er mehrfach am Tag kommt. Wenn ich jetzt also 2-3 Tage nichts mehr von ihm sehe, hat Deine Hilfe dafür gesorgt, dass dieses problem nicht mehr aktuell ist.
Nochmals Danke dafür.
Wenn es in nächster Zeit wider Erwarten doch noch zu Problemen kommt, melde ich mich einfach noch einmal.
VG Heiner