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.
    • mickym
      mickym Most Active @Jacke last edited by mickym

      @jacke Wahrscheinlich einfach. Wenn Du mir mal Deinen Flow zeigen würdest, dann helfe ich Dir gerne. Was sind das für Inputs - woher kommen L1, L2 - hast Du das selbst gesetzt? Tausend Fragen. Nutze wenn möglich am Anfang keine function Nodes. Wenn Du Werte aus unterschiedlichen Nachrichten zusammenzählen möchtest, musst Du diese über einen Kontext oder ein Nachrichtenobjekt sammeln. So laufen die Nachrichten einfach durch, aber die warten ja nicht aufeinander. 😉

      Also poste mal Deinen Flow.

      J 1 Reply Last reply Reply Quote 0
      • 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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            826
                                            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