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
    212

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

  • 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:

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

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

    @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":[]}]
    

    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.

    mickymM 1 Antwort Letzte Antwort
    0
    • mickymM 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":[]}]
      

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

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

      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

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

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

        @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 mickymM 2 Antworten Letzte Antwort
        0
        • R ranzen

          @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 Offline
          R Offline
          ranzen
          schrieb am zuletzt editiert von
          #9

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

            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 Offline
            R Offline
            ranzen
            schrieb am zuletzt editiert von
            #10

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

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

              .

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

              @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

              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

                @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
                schrieb am zuletzt editiert von
                #12

                @mickym

                code_text
                
                
                

                So sah mein Code aus.

                R 1 Antwort Letzte Antwort
                0
                • R ranzen

                  @mickym

                  code_text
                  
                  
                  

                  So sah mein Code aus.

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

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

                  1 Antwort Letzte Antwort
                  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
                    schrieb am zuletzt editiert von
                    #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 Antwort Letzte Antwort
                    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
                      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
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          843

                                          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