Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Node-Red
  5. Node-Red Filter

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    14
    1
    203

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    576

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    1.8k

Node-Red Filter

Geplant Angeheftet Gesperrt Verschoben Node-Red
58 Beiträge 2 Kommentatoren 4.9k Aufrufe 2 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • 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
    schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
    0
    • mickymM Online
      mickymM Online
      mickym
      Most Active
      schrieb am zuletzt editiert von
      #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 Antwort Letzte Antwort
      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
        schrieb am zuletzt editiert von
        #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 Antwort Letzte Antwort
        0
        • mickymM Online
          mickymM Online
          mickym
          Most Active
          schrieb am zuletzt editiert von 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 Antworten Letzte Antwort
          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
            schrieb am zuletzt editiert von
            #19

            @mickym

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

            mickymM 1 Antwort Letzte Antwort
            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
              schrieb am zuletzt editiert von
              #20

              @mickym

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

              1 Antwort Letzte Antwort
              0
              • R ranzen

                @mickym

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

                mickymM Online
                mickymM Online
                mickym
                Most Active
                schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                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
                  schrieb am zuletzt editiert von ranzen
                  #22

                  @mickym

                  Im Copycode steht folgendes:

                  Bildschirmfoto 2024-05-23 um 17.13.11.png

                  R mickymM 2 Antworten Letzte Antwort
                  0
                  • R ranzen

                    @mickym

                    Im Copycode steht folgendes:

                    Bildschirmfoto 2024-05-23 um 17.13.11.png

                    R Offline
                    R Offline
                    ranzen
                    schrieb am zuletzt editiert von
                    #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 Antwort Letzte Antwort
                    0
                    • R ranzen

                      @mickym

                      Im Copycode steht folgendes:

                      Bildschirmfoto 2024-05-23 um 17.13.11.png

                      mickymM Online
                      mickymM Online
                      mickym
                      Most Active
                      schrieb am zuletzt editiert von
                      #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 Antwort Letzte Antwort
                      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
                        schrieb am zuletzt editiert von
                        #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 Antworten Letzte Antwort
                        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
                          schrieb am zuletzt editiert von
                          #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 Antwort Letzte Antwort
                          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 Online
                            mickymM Online
                            mickym
                            Most Active
                            schrieb am zuletzt editiert von
                            #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 Antwort Letzte Antwort
                            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
                              schrieb am zuletzt editiert von
                              #28

                              Ok,

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

                              mickymM 1 Antwort Letzte Antwort
                              0
                              • R ranzen

                                Ok,

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

                                mickymM Online
                                mickymM Online
                                mickym
                                Most Active
                                schrieb am zuletzt editiert von
                                #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 Antwort Letzte Antwort
                                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
                                  schrieb am zuletzt editiert von
                                  #30

                                  @mickym

                                  Bildschirmfoto 2024-05-23 um 17.26.05.png

                                  mickymM 2 Antworten Letzte Antwort
                                  0
                                  • R ranzen

                                    @mickym

                                    Bildschirmfoto 2024-05-23 um 17.26.05.png

                                    mickymM Online
                                    mickymM Online
                                    mickym
                                    Most Active
                                    schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                                    0
                                    • R ranzen

                                      @mickym

                                      Bildschirmfoto 2024-05-23 um 17.26.05.png

                                      mickymM Online
                                      mickymM Online
                                      mickym
                                      Most Active
                                      schrieb am zuletzt editiert von
                                      #32

                                      @ranzen sagte in Node-Red Filter:

                                      @mickym

                                      Bildschirmfoto 2024-05-23 um 17.26.05.png

                                      Ja hier habe ich nur das Ausfiltern bedacht und nicht, wenn die Temperatur nicht -100 ist.

                                      3ce7438c-7efd-4c4e-a8a4-c8237904b18d-image.png

                                      Die JSONATA Regel muss also so aussehen:

                                      payload.temperature = -100 ? payload~>|$|{},"temperature"| : payload
                                      

                                      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 Antwort Letzte Antwort
                                      0
                                      • mickymM mickym

                                        @ranzen sagte in Node-Red Filter:

                                        @mickym

                                        Bildschirmfoto 2024-05-23 um 17.26.05.png

                                        Ja hier habe ich nur das Ausfiltern bedacht und nicht, wenn die Temperatur nicht -100 ist.

                                        3ce7438c-7efd-4c4e-a8a4-c8237904b18d-image.png

                                        Die JSONATA Regel muss also so aussehen:

                                        payload.temperature = -100 ? payload~>|$|{},"temperature"| : payload
                                        
                                        R Offline
                                        R Offline
                                        ranzen
                                        schrieb am zuletzt editiert von
                                        #33

                                        @mickym

                                        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.

                                        R mickymM 2 Antworten Letzte Antwort
                                        0
                                        • R ranzen

                                          @mickym

                                          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.

                                          R Offline
                                          R Offline
                                          ranzen
                                          schrieb am zuletzt editiert von
                                          #34

                                          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.

                                          1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          945

                                          Online

                                          32.5k

                                          Benutzer

                                          81.8k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe