Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Node-Red
    5. Node-Red Filter

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Node-Red Filter

    This topic has been deleted. Only users with topic management privileges can see it.
    • mickym
      mickym Most Active @ranzen last edited by mickym

      Also Du musst nur eine von beiden Methoden verwenden. Dann nimm halt nur die ChangeNode und filtere halt nach der Temperatur direkt deinem Output Deiner function Node..

      Also nur die change Node mit folgendem JSONATA:

      $filter(payload, function($v){$v.temperature > 0})
      
      R 1 Reply Last reply Reply Quote 0
      • R
        ranzen @mickym last edited by

        @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"

        mickym 1 Reply Last reply Reply Quote 0
        • mickym
          mickym Most Active @ranzen last edited by mickym

          @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.

          4cff1973-6f7b-449c-a9a7-6f82611b4726-image.png

          Und dann kopiert man aus dem Debug-Fenster den Wert der payload in die Zwischenablage
          37bb3a53-92ec-437b-a325-d04bd3ec91c8-image.png

          und stellt den hier in CodeTags ein:

          Code-Tags.gif

          [{"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.

          77766d43-23fe-422b-9dea-bf1a61d207ea-image.png

          Hier kannst ja selbst testen oder in die Inject NOde ein Objekt rein machen, was passt.

          [{"id":"e45337f4a3f55c96","type":"inject","z":"289f539dcc33814e","name":"","props":[{"p":"payload"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payload":"[{\"battery\":3.378,\"resistance\":7.386,\"sensorType\":1,\"temperature\":-100,\"trigger\":0}]","payloadType":"json","x":390,"y":6180,"wires":[["6ef399891f05414c","c6fa94570d7b3b5a"]]},{"id":"6ef399891f05414c","type":"debug","z":"289f539dcc33814e","name":"Input","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"payload","targetType":"msg","statusVal":"","statusType":"auto","x":550,"y":6120,"wires":[]},{"id":"c6fa94570d7b3b5a","type":"change","z":"289f539dcc33814e","name":"","rules":[{"t":"set","p":"payload","pt":"msg","to":"$filter(payload, function($v){$v.temperature > 0})","tot":"jsonata"}],"action":"","property":"","from":"","to":"","reg":false,"x":590,"y":6180,"wires":[["ca0c74d4d7932b9f"]]},{"id":"ca0c74d4d7932b9f","type":"debug","z":"289f539dcc33814e","name":"gefiltert","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"payload","targetType":"msg","statusVal":"","statusType":"auto","x":780,"y":6180,"wires":[]}]
          

          mickym 1 Reply Last reply Reply Quote 0
          • mickym
            mickym Most Active @mickym last edited by

            @mickym Und wenn Du nur den negativen Temperaturwert oder -100 herausfiltern willst, dann aktualisierst Du halt das Objekt.

            R 1 Reply Last reply Reply Quote 0
            • R
              ranzen @mickym last edited by

              @mickym

              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);
              

              .

              R mickym 2 Replies Last reply Reply Quote 0
              • R
                ranzen @ranzen last edited by

                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
                
                
                R 1 Reply Last reply Reply Quote 0
                • R
                  ranzen @ranzen last edited by

                  Aber die Fehlermeldung kommt immer noch.

                  Im Change-Node steht als Regel:

                  Setze msg.payload
                  
                  to the value
                  
                  $filter(payload, function($v){$v > 0}) 
                  
                  1 Reply Last reply Reply Quote 0
                  • mickym
                    mickym Most Active @ranzen last edited by

                    @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??

                    04e2511c-5e06-4900-b85f-c4f6a20c4777-image.png

                    R 2 Replies Last reply Reply Quote 0
                    • R
                      ranzen @mickym last edited by

                      @mickym

                      code_text
                      
                      
                      

                      So sah mein Code aus.

                      R 1 Reply Last reply Reply Quote 0
                      • R
                        ranzen @ranzen last edited by

                        @ranzen
                        Ok, jetzt habe ich es kapiert. Debugfenster und dann Schaltfläche Wert.

                        1 Reply Last reply Reply Quote 0
                        • R
                          ranzen @mickym last edited by

                          @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.

                          R 1 Reply Last reply Reply Quote 0
                          • R
                            ranzen @ranzen last edited by ranzen

                            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.

                            1 Reply Last reply Reply Quote 0
                            • mickym
                              mickym Most Active last edited by

                              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.

                              bf4d410e-f531-4f1c-98e8-ca614be791f8-image.png

                              Diese EINE Regel in der Change Node - macht das Gleiche wie dein Javascript Code. Also vielleicht solltest Du Dich mal mit Objekten beschäftigen. 😉

                              R 1 Reply Last reply Reply Quote 0
                              • R
                                ranzen @mickym last edited by

                                @mickym

                                ok, da werde ich mich bestimmt mit beschäftigen.

                                Aber die Fehlermeldung ist immer noch 😉 Im Moment wird die DB nicht bedient.

                                1 Reply Last reply Reply Quote 0
                                • mickym
                                  mickym Most Active last edited by mickym

                                  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:

                                  587e8070-deeb-4353-b6c5-46d5a7c24e7b-image.png

                                  Im ersten Fall kommt also gar nichts hinten raus, wenn in der temperature Eigenschaft -100 steht

                                  R 2 Replies Last reply Reply Quote 0
                                  • R
                                    ranzen @mickym last edited by

                                    @mickym

                                    Ich möchte alles, was kommt, in die DB schreiben. Ausser: -100.

                                    mickym 1 Reply Last reply Reply Quote 0
                                    • R
                                      ranzen @mickym last edited by

                                      @mickym

                                      Dieser Wert -100 zieht mir die schöne Visualisierung vom Grafana runter.

                                      1 Reply Last reply Reply Quote 0
                                      • mickym
                                        mickym Most Active @ranzen last edited by mickym

                                        @ranzen sagte in Node-Red Filter:

                                        @mickym

                                        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.

                                        392d8d06-8574-4c4f-8163-b1dc304730c9-image.png

                                        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.

                                        R 1 Reply Last reply Reply Quote 0
                                        • R
                                          ranzen @mickym last edited by ranzen

                                          @mickym

                                          Im Copycode steht folgendes:

                                          Bildschirmfoto 2024-05-23 um 17.13.11.png

                                          R mickym 2 Replies Last reply Reply Quote 0
                                          • R
                                            ranzen @ranzen last edited by

                                            Ich merke gerade, dass ich überhaupt nicht meine Posts editieren kann.

                                            So sollte die Hardcopy aussehen:

                                            Bildschirmfoto 2024-05-23 um 17.13.11.png

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            811
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            2
                                            58
                                            2620
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo