NEWS
Node-Red Filter
-
@mickym said in Node-Red Filter:
$filter(payload, function($v){$v.temperature > 0})
Da kommt dann die folgende Fehlermeldung:
"Invalid JSONata expression: The expressions either side of operator ">" must evaluate to numeric or string values"
-
@ranzen Ich würde vorschlagen, Du kopierst das was Du filtern willst direkt aus dem Debug Fenster in CodeTags hier rein.
Ich hab das nun zwar mühsam versucht, aber wenn man keine Daten hat, um das nachzustellen, dann kann man auch nicht helfen.
Also schau mal ob Deine Debug Ausgabe so aussieht.
Und dann kopiert man aus dem Debug-Fenster den Wert der payload in die Zwischenablage
und stellt den hier in CodeTags ein:
[{"battery":3.378,"resistance":7.386,"sensorType":1,"temperature":20.5,"trigger":0}]
Dann muss ich keine Gänsefüsschen, Klammern etc selbst drum rum machen.
So und wenn ich nun mit meiner Change Node teste dann werden die Objekte, die eine ungültige Temperatur haben - ausgefiltert - sprich die payload ist undefined (rot markiert). Kannst ggf noch eine Switch Node dahinter machen, um diese Nachrichten komplett zu filtern.
Hier kannst ja selbst testen oder in die Inject NOde ein Objekt rein machen, was passt.
-
@mickym Und wenn Du nur den negativen Temperaturwert oder -100 herausfiltern willst, dann aktualisierst Du halt das Objekt.
-
23.5.2024, 16:30:35node: 2da49fa7d532a2d4 msg.payload : array[1] array[1] 0: object battery: 3.389 resistance: 17.991 sensorType: 1 temperature: 20.900000000000006 trigger: 0
Ja, so der Payload aus, den ich aus der Funktion Richtung DB schicke.
Mein Code in der Funktion sieht so aus:
var msg1 = {}; msg1.payload = [ { battery: msg.payload.uplink_message.decoded_payload["battery"], resistance: msg.payload.uplink_message.decoded_payload["resistance"], sensorType: msg.payload.uplink_message.decoded_payload["sensorType"], temperature: msg.payload.uplink_message.decoded_payload["temperature"], trigger: msg.payload.uplink_message.decoded_payload["trigger"] } ]; return (msg1);
.
-
Und in der DB sieht das dann so aus:
name: apfelbaum1 time battery resistance sensorType temperature trigger ---- ------- ---------- ---------- ----------- ------- 2024-04-08T15:59:41.629377294Z 3.398 1000 1 24.400000000000006 0 2024-04-08T16:14:41.795550813Z 3.401 1000 1 24.400000000000006 0 2024-04-08T16:29:41.794306826Z 3.398 1000 1 24.400000000000006 0 2024-04-08T16:44:41.73256775Z 3.403 1000 1 24.5 0 2024-04-08T16:59:41.786260269Z 3.398 1000 1 24.400000000000006 0 2024-04-08T17:14:41.783145044Z 3.401 1000 1 24.299999999999997 0 2024-04-08T17:44:41.779760184Z 3.401 1000 1 24.200000000000003 0 2024-04-08T17:59:41.612032196Z 3.401 1000 1 24.099999999999994 0 2024-04-08T18:14:41.774595375Z 3.401 1000 1 24 0 2024-04-08T18:29:41.705639142Z 3.401 1000 1 23.900000000000006 0 2024-04-08T18:44:41.768656569Z 3.398 1000 1 23.900000000000006 0 2024-04-08T18:59:41.767234983Z 3.398 1000 1 23.900000000000006 0 2024-04-08T19:14:41.772372995Z 3.401 1000 1 23.799999999999997 0 2024-04-08T19:29:41.768979924Z 3.401 1000 1 23.799999999999997 0 2024-04-08T19:44:41.605064779Z 3.398 1000 1 23.799999999999997 0 2024-04-08T19:59:41.696679475Z 3.398 1000 1 23.799999999999997 0 2024-04-08T20:14:41.776049783Z 3.398 1000 1 23.700000000000003 0 2024-04-08T20:29:41.760546515Z 3.401 1000 1 23.599999999999994 0 2024-04-08T20:44:41.758661338Z 3.398 1000 1 23.599999999999994 0
-
Aber die Fehlermeldung kommt immer noch.
Im Change-Node steht als Regel:
Setze msg.payload to the value $filter(payload, function($v){$v > 0})
-
@ranzen sagte in Node-Red Filter:
23.5.2024, 16:30:35node: 2da49fa7d532a2d4 msg.payload : array[1] array[1] 0: object battery: 3.389 resistance: 17.991 sensorType: 1 temperature: 20.900000000000006 trigger: 0
Du hast schon wieder den Wert nicht über das Debug Fenster und der Schaltfläche Wert kopieren rauskopiert, sondern mit der MAUS - das ist Unsinn. Ich habe Dir doch unten einen Screenshot eingestellt, wie man die Werte sauber aus dem Debugfenster kopiert. So ist das unbrauchbar.
Aber OK - ich habs nochmal transformiert.Das dann nächste ist, Du willst mir nicht sagen, dass Du wegen so einem Input Objekt eine function mit JS Code erstellst??
-
-
@ranzen
Ok, jetzt habe ich es kapiert. Debugfenster und dann Schaltfläche Wert. -
@mickym said in Node-Red Filter:
Das dann nächste ist, Du willst mir nicht sagen, dass Du wegen so einem Input Objekt eine function mit JS Code erstellst??
Doch
So habe ich es mir in den letzten Jahren abgeguckt. Ich mache sehr wenig mit der Jvascipt-Programmierung. Sicherlich geht das eleganter.
-
Wie geht es eleganter ?
Ich hole die Daten per MQTT (in diesem Fall mit MQTT in) von der Quelle ab.
Dann kommt schon die Funktion, in die ich die geholten Daten rein kippe. Und dann in die DB, wo sich Grafana dann bedient.
Das hat bis jetzt immer super funktioniert.
Wenn es eleganter geht. Nur zu, ich lerne gern dazu.
-
Wenn also der Sinn Deiner function Node ist nur das ganze nach oben zu ziehen , da braucht man gar nichts programmieren. Dann nimmt man eine Change Node und VERÄNDERT die payload entsprechend.
Diese EINE Regel in der Change Node - macht das Gleiche wie dein Javascript Code. Also vielleicht solltest Du Dich mal mit Objekten beschäftigen.
-
ok, da werde ich mich bestimmt mit beschäftigen.
Aber die Fehlermeldung ist immer noch Im Moment wird die DB nicht bedient.
-
Ich bin ja auch noch nicht fertig
So ich hab Dir nun 2 Möglichkeiten zum Filtern gemacht - da ich auch noch keine Antwort hatte, ob Du das ganze Objekt wegfiltern willst, wenn die Temperatur -100 ist oder nur die Objekteigenschaft Temperatur:
Im ersten Fall kommt also gar nichts hinten raus, wenn in der temperature Eigenschaft -100 steht
-
Ich möchte alles, was kommt, in die DB schreiben. Ausser: -100.
-
Dieser Wert -100 zieht mir die schöne Visualisierung vom Grafana runter.
-
@ranzen sagte in Node-Red Filter:
Ich möchte alles, was kommt, in die DB schreiben. Ausser: -100.
OK dann hätte ich mir das wahrscheinlich sparen können, dann willst Du also nur die temperature Eigenschaft wegfiltern.
dann sollte also im Prinzip das langen:
[{"id":"487d44863b93b5de","type":"change","z":"289f539dcc33814e","name":"","rules":[{"t":"set","p":"payload","pt":"msg","to":"payload.temperature = -100 ? payload~>|$|{},\"temperature\"|","tot":"jsonata"}],"action":"","property":"","from":"","to":"","reg":false,"x":570,"y":6440,"wires":[["7b3c154c0eb45240"]]}]
Und zum Schluss mach ich Dir noch eine Version, in der Du Dir die ganze function Node sparen kannst.
-
Im Copycode steht folgendes:
-
Ich merke gerade, dass ich überhaupt nicht meine Posts editieren kann.
So sollte die Hardcopy aussehen:
-
@ranzen sagte in Node-Red Filter:
Im Copycode steht folgendes:
Vergiss das doch mit der split Node.
Importiere einfach die Change NOde, aus dem letzten Post und hänge die an Deine function NOde. Das andere kannst Du vergessen.