Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Node-Red
  5. Node-Red Filter

NEWS

  • Wartung am 15.11. – Forum ab 22:00 Uhr nicht erreichbar
    BluefoxB
    Bluefox
    12
    2
    276

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.0k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.7k

Node-Red Filter

Node-Red Filter

Scheduled Pinned Locked Moved Node-Red
58 Posts 2 Posters 4.6k Views 2 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • mickymM mickym

    @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 Offline
    R Offline
    ranzen
    wrote on last edited by
    #12

    @mickym

    code_text
    
    
    

    So sah mein Code aus.

    R 1 Reply Last reply
    0
    • R ranzen

      @mickym

      code_text
      
      
      

      So sah mein Code aus.

      R Offline
      R Offline
      ranzen
      wrote on last edited by
      #13

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

      1 Reply Last reply
      0
      • mickymM mickym

        @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 Offline
        R Offline
        ranzen
        wrote on last edited by
        #14

        @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
        0
        • R ranzen

          @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 Offline
          R Offline
          ranzen
          wrote on last edited by ranzen
          #15

          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
          0
          • mickymM Offline
            mickymM Offline
            mickym
            Most Active
            wrote on last edited by
            #16

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

            Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

            R 1 Reply Last reply
            0
            • mickymM mickym

              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 Offline
              R Offline
              ranzen
              wrote on last edited by
              #17

              @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
              0
              • mickymM Offline
                mickymM Offline
                mickym
                Most Active
                wrote on last edited by mickym
                #18

                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

                Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                R 2 Replies Last reply
                0
                • mickymM 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 Offline
                  R Offline
                  ranzen
                  wrote on last edited by
                  #19

                  @mickym

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

                  mickymM 1 Reply Last reply
                  0
                  • mickymM 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 Offline
                    R Offline
                    ranzen
                    wrote on last edited by
                    #20

                    @mickym

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

                    1 Reply Last reply
                    0
                    • R ranzen

                      @mickym

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

                      mickymM Offline
                      mickymM Offline
                      mickym
                      Most Active
                      wrote on last edited by mickym
                      #21

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

                      Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                      R 1 Reply Last reply
                      0
                      • mickymM 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 Offline
                        R Offline
                        ranzen
                        wrote on last edited by ranzen
                        #22

                        @mickym

                        Im Copycode steht folgendes:

                        Bildschirmfoto 2024-05-23 um 17.13.11.png

                        R mickymM 2 Replies Last reply
                        0
                        • R ranzen

                          @mickym

                          Im Copycode steht folgendes:

                          Bildschirmfoto 2024-05-23 um 17.13.11.png

                          R Offline
                          R Offline
                          ranzen
                          wrote on last edited by
                          #23

                          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
                          0
                          • R ranzen

                            @mickym

                            Im Copycode steht folgendes:

                            Bildschirmfoto 2024-05-23 um 17.13.11.png

                            mickymM Offline
                            mickymM Offline
                            mickym
                            Most Active
                            wrote on last edited by
                            #24

                            @ranzen sagte in Node-Red Filter:

                            @mickym

                            Im Copycode steht folgendes:

                            Bildschirmfoto 2024-05-23 um 17.13.11.png

                            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.

                            Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                            R 1 Reply Last reply
                            0
                            • mickymM mickym

                              @ranzen sagte in Node-Red Filter:

                              @mickym

                              Im Copycode steht folgendes:

                              Bildschirmfoto 2024-05-23 um 17.13.11.png

                              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.

                              R Offline
                              R Offline
                              ranzen
                              wrote on last edited by
                              #25

                              @mickym

                              Das habe ich gerade gemacht.

                              Und trotzdem kommt diese blöde Fehlermeldung wieder:

                              "Invalid JSONata expression: The expressions either side of operator ">" must evaluate to numeric or string values"

                              R mickymM 2 Replies Last reply
                              0
                              • R ranzen

                                @mickym

                                Das habe ich gerade gemacht.

                                Und trotzdem kommt diese blöde Fehlermeldung wieder:

                                "Invalid JSONata expression: The expressions either side of operator ">" must evaluate to numeric or string values"

                                R Offline
                                R Offline
                                ranzen
                                wrote on last edited by
                                #26

                                Moment mal.

                                Was muss ich bei der Regel denn auswählen?

                                Im Moment steht in der letzten Zeile bei "to the value" ein JSONata. Ist das richtig ? Da gibt es ja noch 10 andere Möglichkeiten.

                                R 1 Reply Last reply
                                0
                                • R ranzen

                                  @mickym

                                  Das habe ich gerade gemacht.

                                  Und trotzdem kommt diese blöde Fehlermeldung wieder:

                                  "Invalid JSONata expression: The expressions either side of operator ">" must evaluate to numeric or string values"

                                  mickymM Offline
                                  mickymM Offline
                                  mickym
                                  Most Active
                                  wrote on last edited by
                                  #27

                                  @ranzen Kannst Du mal einen Screenshot von dem Flow machen

                                  d5604161-4c14-4de7-8940-99e35f145480-image.png

                                  Wenn Du nur diese Node hast - bekomme ich , wenn Dein Objekt das wie im Input dargestellt KEINE Fehler.

                                  Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                  1 Reply Last reply
                                  0
                                  • R ranzen

                                    Moment mal.

                                    Was muss ich bei der Regel denn auswählen?

                                    Im Moment steht in der letzten Zeile bei "to the value" ein JSONata. Ist das richtig ? Da gibt es ja noch 10 andere Möglichkeiten.

                                    R Offline
                                    R Offline
                                    ranzen
                                    wrote on last edited by
                                    #28

                                    Ok,

                                    habe mir gerade die kleine Grafik noch mal angeschaut. Da muss "msg" stehen.

                                    mickymM 1 Reply Last reply
                                    0
                                    • R ranzen

                                      Ok,

                                      habe mir gerade die kleine Grafik noch mal angeschaut. Da muss "msg" stehen.

                                      mickymM Offline
                                      mickymM Offline
                                      mickym
                                      Most Active
                                      wrote on last edited by
                                      #29

                                      @ranzen sagte in Node-Red Filter:

                                      Ok,

                                      habe mir gerade die kleine Grafik noch mal angeschaut. Da muss "msg" stehen.

                                      Ach Du meinst um deine function Node zu ersetzen. Da ja!

                                      Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                      R 1 Reply Last reply
                                      0
                                      • mickymM mickym

                                        @ranzen sagte in Node-Red Filter:

                                        Ok,

                                        habe mir gerade die kleine Grafik noch mal angeschaut. Da muss "msg" stehen.

                                        Ach Du meinst um deine function Node zu ersetzen. Da ja!

                                        R Offline
                                        R Offline
                                        ranzen
                                        wrote on last edited by
                                        #30

                                        @mickym

                                        Bildschirmfoto 2024-05-23 um 17.26.05.png

                                        mickymM 2 Replies Last reply
                                        0
                                        • R ranzen

                                          @mickym

                                          Bildschirmfoto 2024-05-23 um 17.26.05.png

                                          mickymM Offline
                                          mickymM Offline
                                          mickym
                                          Most Active
                                          wrote on last edited by mickym
                                          #31

                                          War noch ein Fehler bei mir drin. - Sorry

                                          857d1236-8f28-4dfc-b95b-40949d4b2e12-image.png

                                          So diese Change Node ersetzt deine Function Node und filtert die -100 raus.

                                          Hier nochmal frisch zum Import

                                          [{"id":"2e349cf5c3330d81","type":"inject","z":"289f539dcc33814e","name":"","props":[{"p":"payload.uplink_message.decoded_payload","v":"[{\"battery\":3.389,\"resistance\":17.991,\"sensorType\":1,\"temperature\":20.900000000000006,\"trigger\":0}]","vt":"json"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","x":170,"y":6600,"wires":[["082976a6c8ee17e5","7ddaae9966eaa43f"]]},{"id":"082976a6c8ee17e5","type":"debug","z":"289f539dcc33814e","name":"input","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"payload","targetType":"msg","statusVal":"","statusType":"auto","x":310,"y":6560,"wires":[]},{"id":"7ddaae9966eaa43f","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":350,"y":6600,"wires":[["8f4233382dd7838e"]]},{"id":"8f4233382dd7838e","type":"debug","z":"289f539dcc33814e","name":"nur Temperatur weggefiltert","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"payload","targetType":"msg","statusVal":"","statusType":"auto","x":600,"y":6600,"wires":[]}]
                                          

                                          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          194

                                          Online

                                          32.4k

                                          Users

                                          81.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe