Navigation

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

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Node Red Werte addieren

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

      @mickym
      den code den ich bei Function hinterlegt habe war aus diversen Beiträgen raus kopiert ich denke das war grundsätzlich falsch. deshalb lasse ich es mal weg.
      0c78890d-c755-411a-9d0e-190f69ec517d-image.png
      SInd value Werte aus IoBroker.
      Dachte ich versuche es mal mit Node Red es sah übersichtlicher aus als meine blockly und javaskripte.
      Danke

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

        @jacke Ist auch nicht schwierig - wie gesagt aus den L1, L2, L3 kommt es zu unterschiedlichen Zeiten die payload. Am Besten machst Du folgendes.

        Ich simuliere mal Deine iobroker-IN Nodes mit Inject Nodes. Die kannst Du dann mit Deinen iobroker-In Nodes bzw. an die Topic Nodes anflanschen.

        4e82b1b8-b993-4575-b69d-b587b53f7eab-image.png

        Hier der Flow:

        [
           {
               "id": "07ae2369fe461fbe",
               "type": "change",
               "z": "54b226bc.0793e8",
               "name": "topic: L1",
               "rules": [
                   {
                       "t": "set",
                       "p": "topic",
                       "pt": "msg",
                       "to": "L1",
                       "tot": "str"
                   }
               ],
               "action": "",
               "property": "",
               "from": "",
               "to": "",
               "reg": false,
               "x": 340,
               "y": 2720,
               "wires": [
                   [
                       "a244a31c5bcbea91"
                   ]
               ]
           },
           {
               "id": "bf7144a4e29d4279",
               "type": "change",
               "z": "54b226bc.0793e8",
               "name": "topic: L2",
               "rules": [
                   {
                       "t": "set",
                       "p": "topic",
                       "pt": "msg",
                       "to": "L2",
                       "tot": "str"
                   }
               ],
               "action": "",
               "property": "",
               "from": "",
               "to": "",
               "reg": false,
               "x": 340,
               "y": 2780,
               "wires": [
                   [
                       "a244a31c5bcbea91"
                   ]
               ]
           },
           {
               "id": "64441cb4c466b694",
               "type": "change",
               "z": "54b226bc.0793e8",
               "name": "topic: L3",
               "rules": [
                   {
                       "t": "set",
                       "p": "topic",
                       "pt": "msg",
                       "to": "L3",
                       "tot": "str"
                   }
               ],
               "action": "",
               "property": "",
               "from": "",
               "to": "",
               "reg": false,
               "x": 340,
               "y": 2840,
               "wires": [
                   [
                       "a244a31c5bcbea91"
                   ]
               ]
           },
           {
               "id": "a244a31c5bcbea91",
               "type": "join",
               "z": "54b226bc.0793e8",
               "name": "",
               "mode": "custom",
               "build": "object",
               "property": "payload",
               "propertyType": "msg",
               "key": "topic",
               "joiner": "\\n",
               "joinerType": "str",
               "accumulate": true,
               "timeout": "",
               "count": "3",
               "reduceRight": false,
               "reduceExp": "",
               "reduceInit": "",
               "reduceInitType": "",
               "reduceFixup": "",
               "x": 530,
               "y": 2780,
               "wires": [
                   [
                       "add94d9ab1b506bd"
                   ]
               ]
           },
           {
               "id": "3ceea4dfeb31a8e4",
               "type": "debug",
               "z": "54b226bc.0793e8",
               "name": "",
               "active": true,
               "tosidebar": true,
               "console": false,
               "tostatus": false,
               "complete": "false",
               "statusVal": "",
               "statusType": "auto",
               "x": 930,
               "y": 2780,
               "wires": []
           },
           {
               "id": "add94d9ab1b506bd",
               "type": "change",
               "z": "54b226bc.0793e8",
               "name": "",
               "rules": [
                   {
                       "t": "set",
                       "p": "payload",
                       "pt": "msg",
                       "to": "payload.L1 + payload.L2 +payload.L3",
                       "tot": "jsonata"
                   },
                   {
                       "t": "set",
                       "p": "topic",
                       "pt": "msg",
                       "to": "Summe von L1,L2,L3",
                       "tot": "str"
                   }
               ],
               "action": "",
               "property": "",
               "from": "",
               "to": "",
               "reg": false,
               "x": 730,
               "y": 2780,
               "wires": [
                   [
                       "3ceea4dfeb31a8e4"
                   ]
               ]
           }
        ]
        

        Wenn Du eine Erklärung möchtest, dann musst Du es sagen.

        Wenn Du es unbedingt mit einer function Node machen willst, geht das auch - aber dann programmierst Du halt wieder.

        J _ 2 Replies Last reply Reply Quote 0
        • J
          Jacke @mickym last edited by

          @mickym said in Node Red Werte addieren:

          Wenn Du es unbedingt mit einer function Node machen willst, geht das auch - aber dann programmierst Du halt wieder.

          Ja würde ich es gerne mit einer function hinbekommen.
          Mittels aggregator würde es auch klappen.

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

            @jacke Dann poste mal die topics bzw. die Pfade Deiner In-Nodes - weil mir das zu blöde ist, dass nun abzuschreiben. Ich empfehle es Dir aber nicht. Ausser Du nutzt die msg.topics aus meinem Flow.

            J 1 Reply Last reply Reply Quote 0
            • J
              Jacke @mickym last edited by

              @mickym
              Vielen Dank erstmal

              hier die Topics

              modbus.1.holdingRegisters.30.2600_L1_Power
              modbus.1.holdingRegisters.30.2601_L2_Power
              modbus.1.holdingRegisters.30.2602_L3_Power

              Output

              javascript.0.Victron.Grid_Power_ges

              Warum würdest du es nicht empfehlen?

              mickym 2 Replies Last reply Reply Quote 0
              • mickym
                mickym Most Active @Jacke last edited by mickym

                @jacke sagte in Node Red Werte addieren:

                javascript.0.Victron.Grid_Power_ges

                [
                    {
                        "id": "667272205d9e793d",
                        "type": "function",
                        "z": "54b226bc.0793e8",
                        "name": "",
                        "func": "if (msg.topic === \"modbus/1/holdingRegisters/30/2600_L1_Power\") context.set(\"L1\",msg.payload);\nif (msg.topic === \"modbus/1/holdingRegisters/30/2601_L2_Power\") context.set(\"L2\",msg.payload);\nif (msg.topic === \"modbus/1/holdingRegisters/30/2602_L3_Power\") context.set(\"L3\",msg.payload);\n\nvar L1 = context.get(\"L1\") || 0;\nvar L2 = context.get(\"L2\") || 0;\nvar L3 = context.get(\"L3\") || 0;\n\nmsg.payload = L1 + L2 + L3;\nreturn msg;",
                        "outputs": 1,
                        "noerr": 0,
                        "initialize": "",
                        "finalize": "",
                        "libs": [],
                        "x": 580,
                        "y": 3020,
                        "wires": [
                            [
                                "1da4ea31822da769",
                                "046b1abfd637abb8"
                            ]
                        ]
                    },
                    {
                        "id": "046b1abfd637abb8",
                        "type": "ioBroker out",
                        "z": "54b226bc.0793e8",
                        "name": "",
                        "topic": "javascript.0.Victron.Grid_Power_ges",
                        "ack": "false",
                        "autoCreate": "false",
                        "stateName": "",
                        "role": "",
                        "payloadType": "",
                        "readonly": "",
                        "stateUnit": "",
                        "stateMin": "",
                        "stateMax": "",
                        "x": 830,
                        "y": 3020,
                        "wires": []
                    }
                ]
                

                Hier der Flow:

                db24c46e-4809-40a4-9575-11a83ca665ce-image.png

                Musst nur noch deine 3 iobroker In Nodes dran hängen.

                Hier der Code der Function Node:

                if (msg.topic === "modbus/1/holdingRegisters/30/2600_L1_Power") context.set("L1",msg.payload);
                if (msg.topic === "modbus/1/holdingRegisters/30/2601_L2_Power") context.set("L2",msg.payload);
                if (msg.topic === "modbus/1/holdingRegisters/30/2602_L3_Power") context.set("L3",msg.payload);
                
                var L1 = context.get("L1") || 0;
                var L2 = context.get("L2") || 0;
                var L3 = context.get("L3") || 0;
                
                msg.payload = L1 + L2 + L3;
                return msg;
                

                Den Inhalt Deiner Variablen im Kontext Deiner function Node siehst Du im Übrigen im Kontextmenü:

                cabbd979-30f2-4646-b251-854758c6c05f-image.png

                EDIT:

                Habe unten gerade Deinen Screenshot betrachtet - das Topic wird mit "/" und nicht mit "." ausgegeben. Das ist so eine Eigenart der iobroker-IN Nodes. Habe deshalb den Code in der Function NOde nochmal angepasst.

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

                  @jacke sagte in Node Red Werte addieren:

                  Warum würdest du es nicht empfehlen?

                  Nun weil Du Dir die Nachvollziehbarkeit und den Flow/Ablauf versteckst und damit alle Möglichkeiten der Fehlersuche verloren gehen.

                  Ich habe das hier mal erläutert:

                  https://forum.iobroker.net/topic/40242/msg-payload-werte-auslesen/22?_=1647358315252

                  Wo siehst Du besser was passiert

                  Hier?

                  1b1638d9-9719-407a-aead-f387a58db5c4-image.png

                  oder hier?

                  4cf05833-3f7c-44c3-bbe7-e15d166c0275-image.png

                  Du kannst jeden Flow in eine Function Node packen und Javascript programmieren, dann brauchst aber kein Node Red, sondern dann nimmst einfach den Javascript Adapter.

                  Die function Node - entspricht im Blockly diesem:

                  8d9290b7-8916-4a0b-b15e-e76c2f76808a-image.png

                  So in diese JS Funktion kannst Du Deine gesamte Logik packen - dann brauchst Du keinen einzigen Baustein Deines Blocklies ausser dem Aufruf.

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

                    @jacke Und nochmal zur Erklärung die Nachrichten warten nicht.
                    70c600f9-f55b-4b19-9de1-54f867ab2e2c-image.png

                    Was passiert mit Deinem Flow - ohne den Inhalt der function Node zu kennen:

                    1. Die Node L1 sendet eine payload mit dem Wert 233 in die function Node. Die 233 werden wie auch immer verarbeitet und das ergebnis an die Debug NOde weitergegeben. Ohne Speicherung in der Funktion Node - ist alles wieder verloren.
                    2. Die Node L2 sendet eine payload mit dem Wert 126 in die function NOde. Die 126 werden wie auch immer verarbeitet und das Ergebnis an die Debug Node weitergegeben. Was soll hier addiert werden - die 233 aus der 1. Node sind in der function Node nicht gespeichert.

                    Also immer im Hinterkopf - Nachrichten warten nicht. Du kannst verschiedene Werte über einen Kontext speichern oder in einem Nachrichtenobjekt wie ich das mit der JOIN Node gemacht habe. Da werden die Werte dann als Eigenschaften mitgeschleppt.

                    Ein Hilfe zum Kontext ist übrigens in der Hilfe Deiner function Node verlinkt:

                    f9f4a499-19e8-478c-8364-6d972d1b523d-image.png

                    H 1 Reply Last reply Reply Quote 0
                    • H
                      htom89 @mickym last edited by

                      @mickym
                      Hi, bei mir klappt es leider nur halb.
                      Die Werte von L1, L2, L3 werden hintereinander geschrieben und nicht addiert.
                      Was mache ich den da falsch?
                      a0720d8c-fab6-480b-97d3-29a4602e148a-image.png
                      fc29c970-0f2f-4f48-8177-6e0f30a3f870-image.png
                      Danke für die Hilfe

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

                        @htom89 Wahrscheinlich hast Du in Deiner Adapterkonfiguration alle Werte in Zeichenketten konvertiert und nicht umgestellt und Du wandelst alles in Strings um. Dann werden diese auch nur aneinandergehängt und nicht gerechnet.

                        Schau mal die Adapterkonfiguration an und mach den Haken raus:

                        e85a943f-e8df-42a3-b2de-6616103968be-image.png

                        H 1 Reply Last reply Reply Quote 1
                        • H
                          htom89 @mickym last edited by

                          @mickym
                          Danke für die sehr schnelle Hilfe! Das war die Ursache! 🙂

                          1 Reply Last reply Reply Quote 0
                          • _
                            _R_A_L_F_ @mickym last edited by

                            @mickym said in Node Red Werte addieren:

                            Hallo @mickym,
                            ich stehe gerade vor dem gleichen Problem zwecks Addition in Node-Red und wollte dies wie hier über das Change Node realisiern.
                            Aber ich weiß nicht genau, was hier genau falsch ist?
                            3b232204-0eba-4ad4-ba2c-9cd9f037dbd8-grafik.png

                            An sich sind die Payloads der Wert vom Objekt.

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

                              @_r_a_l_f_ JSONATA mag die Klammerschreibweise nicht, da das einen Filter darstellt.

                              Probiere:

                              payload.‘0_userdata/0……‘
                              
                              _ 1 Reply Last reply Reply Quote 0
                              • _
                                _R_A_L_F_ @mickym last edited by _R_A_L_F_

                                @mickym Da kommt leider undefined im Payload Ergebnis. Ich habe statt ' mal " genommen und so klappts. Vielen Dank für die schnelle Hilfe 😉

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

                                  @_r_a_l_f_

                                  So sollte es auch gehen:

                                  $lookup(payload,"0_userdata....Keller...") + $lookup(payload,"0_userdata....Bad...")
                                  
                                  _ 1 Reply Last reply Reply Quote 0
                                  • _
                                    _R_A_L_F_ @Marc Berg last edited by

                                    @marc-berg Danke dir für den Tipp. So wie @mickym es geschrieben hat klappt es fast. Nur ' durch "" ersetzen und schon klappts 😉

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

                                      @_r_a_l_f_ sagte in Node Red Werte addieren:

                                      @mickym Da kommt leider undefined im Payload Ergebnis. Ich habe statt ' mal " genommen und so klappts. Vielen Dank für die schnelle Hilfe 😉

                                      Ja manchmal muss ich auch probieren. 😉 - Im Übrigen von @Marc-Berg s Lösung - kürze ich die topics meist bevor ich die Datenpunkte in einem Objekt zusammenfasse.

                                      S 1 Reply Last reply Reply Quote 0
                                      • S
                                        siporax @mickym last edited by

                                        Hänge mich mir mal rein da ich fast das gleiche vorhabe.
                                        Habe zum ersten mal mit node red zu tun.

                                        Möchte von meinem Stromzähler den ich über den iobroker laufen habe von L1 +L2+L3 zusammen adieren lassen damit ich ein Gesamtverbrauch habe in Watt und diesen Wert dann weiterverwenden kann.
                                        Später mal mit Grafana.

                                        Kann mir da mal einer helfen wie ich das anstelle soll.

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

                                          @siporax Wie im Anfang Posting beschrieben, alle werte L1-L3 in eine Eigenschaft des Nachrichtenobjektes sammeln und dann zusammenzählen. Über das Attribut kannst Du ja jeden Wert einer anderen Nachrichteneigenschaft zuweisen.

                                          8bd773b5-9d91-4d0c-8262-4920e0321307-image.png

                                          Hier zum Import:

                                          [
                                             {
                                                 "id": "a872a7ba51fd3484",
                                                 "type": "inject",
                                                 "z": "7e6af0015415146d",
                                                 "name": "",
                                                 "props": [
                                                     {
                                                         "p": "trigger",
                                                         "v": "true",
                                                         "vt": "bool"
                                                     }
                                                 ],
                                                 "repeat": "",
                                                 "crontab": "",
                                                 "once": false,
                                                 "onceDelay": 0.1,
                                                 "topic": "",
                                                 "x": 150,
                                                 "y": 4320,
                                                 "wires": [
                                                     [
                                                         "256da960d23f9755"
                                                     ]
                                                 ]
                                             },
                                             {
                                                 "id": "256da960d23f9755",
                                                 "type": "ioBroker get",
                                                 "z": "7e6af0015415146d",
                                                 "name": "L1",
                                                 "topic": "0_userdata.0.test0.test.temperature:100",
                                                 "attrname": "L1",
                                                 "payloadType": "value",
                                                 "errOnInvalidState": "nothing",
                                                 "x": 290,
                                                 "y": 4320,
                                                 "wires": [
                                                     [
                                                         "a4730fef776c6647"
                                                     ]
                                                 ]
                                             },
                                             {
                                                 "id": "a4730fef776c6647",
                                                 "type": "ioBroker get",
                                                 "z": "7e6af0015415146d",
                                                 "name": "L2",
                                                 "topic": "0_userdata.0.test0.test.temperature:101",
                                                 "attrname": "L2",
                                                 "payloadType": "value",
                                                 "errOnInvalidState": "nothing",
                                                 "x": 430,
                                                 "y": 4320,
                                                 "wires": [
                                                     [
                                                         "9685e5e1edcb1ba4"
                                                     ]
                                                 ]
                                             },
                                             {
                                                 "id": "c5166dda9c56917b",
                                                 "type": "debug",
                                                 "z": "7e6af0015415146d",
                                                 "name": "Summe",
                                                 "active": true,
                                                 "tosidebar": true,
                                                 "console": false,
                                                 "tostatus": false,
                                                 "complete": "payload",
                                                 "targetType": "msg",
                                                 "statusVal": "",
                                                 "statusType": "auto",
                                                 "x": 800,
                                                 "y": 4320,
                                                 "wires": []
                                             },
                                             {
                                                 "id": "9685e5e1edcb1ba4",
                                                 "type": "change",
                                                 "z": "7e6af0015415146d",
                                                 "name": "",
                                                 "rules": [
                                                     {
                                                         "t": "set",
                                                         "p": "payload",
                                                         "pt": "msg",
                                                         "to": "L1 + L2",
                                                         "tot": "jsonata"
                                                     }
                                                 ],
                                                 "action": "",
                                                 "property": "",
                                                 "from": "",
                                                 "to": "",
                                                 "reg": false,
                                                 "x": 610,
                                                 "y": 4320,
                                                 "wires": [
                                                     [
                                                         "c5166dda9c56917b"
                                                     ]
                                                 ]
                                             }
                                          ]
                                          

                                          S 1 Reply Last reply Reply Quote 0
                                          • S
                                            siporax @mickym last edited by

                                            habs mal so importiert denke ich muss die L1 bis L3 über Topic neu zuweisen da meine Adressen ja andere sind.
                                            Was muss ich da noch ändern das es passt.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            563
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

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