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. Gelöst: Wert in dynamische Struktur im ioBroker ablegen

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Gelöst: Wert in dynamische Struktur im ioBroker ablegen

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

      @martybr Also - ich habe nun gerade Deinen Flow importiert. Wäre übrigens auch gut, wenn Du mir eine Inject Node zur Simulation dran machen würdest, da ich ja in der Regel nicht deine Datenpunkte habe.

      fd30903d-89c5-4082-aaa2-12ba226df6d9-image.png

      Dann machst Du einen gravierenden Fehler, wenn Du in JSONATA meinst, du kannst "array-bezug" schreiben. Dann versucht JSONATA von einer Nachrichteneigenschaft "array" den Betrag der Nachrichteneigenschaft "bezug" zu subtrahieren, was natürlich beides nicht definiert bzw. exisitiert.
      Ich habe also in Deinem ganzen Flow - "array-bezug" durch "array_bezug" ersetzt.

      Dann haben wir doch besprochen, dass der iobroker KEINE Objekte bearbeiten kann. Also müssen wir bevor wir einen Datenpunkt beschreiben, diesen erst in einen String umwandeln.

      Also lösche Deinen Datenpunkt nochmals und setze eine JSON Node vor die iobroker-Out Node, so wie besprochen.

      28ba5b0e-3db0-4a42-bb5c-d0b67738c51e-image.png

      Und zuletzt - speicherst Du zwar direkt in die Flow variable - aber Du wolltest doch persistent machen und Du liest ja nirgend Dein Array aus dem iobroker wieder ein?

      Also hören wir doch mal auf, das Ergebnis - also das neue Array direkt abzuspeichern:

      90ff446d-e8aa-4850-a3c9-a4e42669b7cf-image.png

      So nun muss man also wieder was aus dem Datenpunkt einlesen, den man in iobroker geschrieben hat. das ist aber kompliziert, da der Datenpunkt ja dynamisch sich dauernd ändert. Ich überlege mir mal was.

      Inzwischen kannst Du Dir ja den modifizierten Flow - als Basis schon mal abspeichern - dann auf der Basis machen wir weiter.

      [
         {
             "id": "ae673cf6cd8433a0",
             "type": "subflow",
             "name": "Datum in Topic",
             "info": "",
             "category": "",
             "in": [
                 {
                     "x": 60,
                     "y": 80,
                     "wires": [
                         {
                             "id": "2e1ea06b2e94bf1a"
                         }
                     ]
                 }
             ],
             "out": [
                 {
                     "x": 820,
                     "y": 80,
                     "wires": [
                         {
                             "id": "fc37f5f9d2b0297b",
                             "port": 0
                         }
                     ]
                 }
             ],
             "env": [
                 {
                     "name": "basePath",
                     "type": "str",
                     "value": "Test1.Test2"
                 }
             ],
             "meta": {},
             "color": "#DDAA99"
         },
         {
             "id": "2e1ea06b2e94bf1a",
             "type": "change",
             "z": "ae673cf6cd8433a0",
             "name": "",
             "rules": [
                 {
                     "t": "set",
                     "p": "datum",
                     "pt": "msg",
                     "to": "$moment().locale('de').format('YYYY.MMMM')",
                     "tot": "jsonata"
                 }
             ],
             "action": "",
             "property": "",
             "from": "",
             "to": "",
             "reg": false,
             "x": 230,
             "y": 80,
             "wires": [
                 [
                     "0e8de9437c3c420a"
                 ]
             ]
         },
         {
             "id": "0e8de9437c3c420a",
             "type": "change",
             "z": "ae673cf6cd8433a0",
             "name": "März zu Maerz",
             "rules": [
                 {
                     "t": "change",
                     "p": "datum",
                     "pt": "msg",
                     "from": "März",
                     "fromt": "str",
                     "to": "Maerz",
                     "tot": "str"
                 }
             ],
             "action": "",
             "property": "",
             "from": "",
             "to": "",
             "reg": false,
             "x": 440,
             "y": 80,
             "wires": [
                 [
                     "fc37f5f9d2b0297b"
                 ]
             ]
         },
         {
             "id": "fc37f5f9d2b0297b",
             "type": "change",
             "z": "ae673cf6cd8433a0",
             "name": "",
             "rules": [
                 {
                     "t": "set",
                     "p": "topic",
                     "pt": "msg",
                     "to": "\"0_userdata.0.\"  & $env(\"basePath\") & \".\" & datum & \".\" & topic",
                     "tot": "jsonata"
                 }
             ],
             "action": "",
             "property": "",
             "from": "",
             "to": "",
             "reg": false,
             "x": 660,
             "y": 80,
             "wires": [
                 []
             ]
         },
         {
             "id": "5073270521431406",
             "type": "debug",
             "z": "5dbdd0fd840b4eee",
             "name": "debug 184",
             "active": true,
             "tosidebar": true,
             "console": false,
             "tostatus": false,
             "complete": "false",
             "statusVal": "",
             "statusType": "auto",
             "x": 1170,
             "y": 300,
             "wires": []
         },
         {
             "id": "10bd7990f72c7776",
             "type": "ioBroker out",
             "z": "5dbdd0fd840b4eee",
             "name": "",
             "topic": "",
             "ack": "true",
             "autoCreate": "true",
             "stateName": "",
             "role": "",
             "payloadType": "",
             "readonly": "false",
             "stateUnit": "",
             "stateMin": "",
             "stateMax": "",
             "x": 1340,
             "y": 220,
             "wires": []
         },
         {
             "id": "147888cb9d8dbd57",
             "type": "subflow:ae673cf6cd8433a0",
             "z": "5dbdd0fd840b4eee",
             "name": "",
             "env": [
                 {
                     "name": "basePath",
                     "value": "Test1.Test5.MonatsTabellen",
                     "type": "str"
                 }
             ],
             "x": 1000,
             "y": 160,
             "wires": [
                 [
                     "5073270521431406",
                     "c097566fbf70cacc"
                 ]
             ]
         },
         {
             "id": "9226f70990baa228",
             "type": "change",
             "z": "5dbdd0fd840b4eee",
             "name": "",
             "rules": [
                 {
                     "t": "set",
                     "p": "payload",
                     "pt": "msg",
                     "to": "$append(array_bezug, payload)",
                     "tot": "jsonata"
                 }
             ],
             "action": "",
             "property": "",
             "from": "",
             "to": "",
             "reg": false,
             "x": 790,
             "y": 160,
             "wires": [
                 [
                     "147888cb9d8dbd57"
                 ]
             ]
         },
         {
             "id": "102ed68150c3074f",
             "type": "change",
             "z": "5dbdd0fd840b4eee",
             "name": "Vorhandenes Array",
             "rules": [
                 {
                     "t": "set",
                     "p": "array_bezug",
                     "pt": "msg",
                     "to": "array_bezug",
                     "tot": "flow"
                 },
                 {
                     "t": "set",
                     "p": "array_bezug",
                     "pt": "msg",
                     "to": "array_bezug ? array_bezug : []",
                     "tot": "jsonata"
                 }
             ],
             "action": "",
             "property": "",
             "from": "",
             "to": "",
             "reg": false,
             "x": 570,
             "y": 160,
             "wires": [
                 [
                     "9226f70990baa228"
                 ]
             ]
         },
         {
             "id": "fbcf46d8f94203aa",
             "type": "change",
             "z": "5dbdd0fd840b4eee",
             "name": "Bezug",
             "rules": [
                 {
                     "t": "set",
                     "p": "topic",
                     "pt": "msg",
                     "to": "Strombezug",
                     "tot": "str"
                 }
             ],
             "action": "",
             "property": "",
             "from": "",
             "to": "",
             "reg": false,
             "x": 350,
             "y": 120,
             "wires": [
                 [
                     "102ed68150c3074f"
                 ]
             ]
         },
         {
             "id": "a435b3ce1f53ba74",
             "type": "ioBroker in",
             "z": "5dbdd0fd840b4eee",
             "d": true,
             "name": "Bezug täglich",
             "attrname": "payload",
             "topic": "0_userdata.0.Zaehler.Strombezug.Verbrauch.täglich",
             "payloadType": "value",
             "onlyack": "",
             "func": "all",
             "gap": "",
             "fireOnStart": "true",
             "outFormat": "MQTT",
             "x": 110,
             "y": 160,
             "wires": [
                 [
                     "fbcf46d8f94203aa"
                 ]
             ]
         },
         {
             "id": "779ae42084de3e0c",
             "type": "inject",
             "z": "5dbdd0fd840b4eee",
             "name": "",
             "props": [
                 {
                     "p": "payload"
                 },
                 {
                     "p": "topic",
                     "vt": "str"
                 }
             ],
             "repeat": "",
             "crontab": "",
             "once": false,
             "onceDelay": 0.1,
             "topic": "Bezug täglich",
             "payload": "20.1",
             "payloadType": "num",
             "x": 110,
             "y": 120,
             "wires": [
                 [
                     "fbcf46d8f94203aa"
                 ]
             ]
         },
         {
             "id": "c097566fbf70cacc",
             "type": "json",
             "z": "5dbdd0fd840b4eee",
             "name": "",
             "property": "payload",
             "action": "",
             "pretty": false,
             "x": 1170,
             "y": 220,
             "wires": [
                 [
                     "10bd7990f72c7776"
                 ]
             ]
         }
      ]
      

      =============================================================

      Ich denke, ich muss den ganzen Flow etwas umstellen, damit es auch einigermaßen effizient wird. Also vergiß Deinen/Meinen bisherigen Flow.

      M 1 Reply Last reply Reply Quote 0
      • M
        MartyBr @mickym last edited by

        @mickym
        Konntest du dir den Flow zur Monatslänge (von 9:48 Uhr) mal anschauen? Ich habe da eine globale Variable "Monatstage" definiert.

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

          @martybr Warum das nun wieder - ich habe den Flow nun fertig und wenn der Monat wechselt wird automatisch ein neuer Datenpunkt durch Deinen Subflow angelegt und auch eingelesen.

          Nein Sorry - Du hast Recht, wenn sich das Topic ändert, dann muss die Flowvariable noch gelöscht werden. Habe ich vergessen.

          M 1 Reply Last reply Reply Quote 0
          • M
            MartyBr @mickym last edited by

            @mickym
            Vielleicht irre ich mich auch. Ich habe von einem lieben Bekannten ein JavaScript, welches über die Werte iteriert. Hier werden die Zahl der Tage im Monat benötigt. Ich versuche hier mit deiner Hilfe Node-Red zu verstehen, da mich Javascript nicht angesprochen hat. Da gibt es mit async etc. genügend Fallstricke.
            Daher kommen manche meiner Fragen, die für die bestimmt selbstverständlich sind. Ich fange ja gerade erst mit Node-Red an. Das Buch das ich mir gekauft habe war nicht so toll.
            Einges habe ich schon in Node-Red umsetzen können:
            Meine Bewegungsmelder mit Zeitsteuerung und Sperre bei manuellem Auslösen und mit deiner Hilfe die Speicherung von Strombezug und Einspeisung.
            Ich konnte mit den Flows das ganze und weitere Anwendungen umsetzen, z.B. Wasserverbrauch, Gartenwasser, Solareinspeisung. Dadurch habe ich das Potential von Node-Red erkannt. Nun habe ich Zeit und versuche mich tiefer einzuarbeiten 😇

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

              @martybr Ja ich schau mir das gleich an -

              Aber zu deinem Flow mit den dynamischen Monatsarrays habe ich eine andere Lösung, da brauchst du die Zahl nicht. Sprich wenn sich das topic ändert, dann wird die bisherige flow Variable gelöscht und eine neue erstellt. Schau Dir erst mal den neuen Flow an:

              57807547-2b59-4a63-9397-78760c0864a3-image.png

              [
                 {
                     "id": "ae673cf6cd8433a0",
                     "type": "subflow",
                     "name": "Datum in Topic",
                     "info": "",
                     "category": "",
                     "in": [
                         {
                             "x": 60,
                             "y": 80,
                             "wires": [
                                 {
                                     "id": "2e1ea06b2e94bf1a"
                                 }
                             ]
                         }
                     ],
                     "out": [
                         {
                             "x": 820,
                             "y": 80,
                             "wires": [
                                 {
                                     "id": "fc37f5f9d2b0297b",
                                     "port": 0
                                 }
                             ]
                         }
                     ],
                     "env": [
                         {
                             "name": "basePath",
                             "type": "str",
                             "value": "Test1.Test2"
                         }
                     ],
                     "meta": {},
                     "color": "#DDAA99"
                 },
                 {
                     "id": "2e1ea06b2e94bf1a",
                     "type": "change",
                     "z": "ae673cf6cd8433a0",
                     "name": "",
                     "rules": [
                         {
                             "t": "set",
                             "p": "datum",
                             "pt": "msg",
                             "to": "$moment().locale('de').format('YYYY.MMMM')",
                             "tot": "jsonata"
                         }
                     ],
                     "action": "",
                     "property": "",
                     "from": "",
                     "to": "",
                     "reg": false,
                     "x": 230,
                     "y": 80,
                     "wires": [
                         [
                             "0e8de9437c3c420a"
                         ]
                     ]
                 },
                 {
                     "id": "0e8de9437c3c420a",
                     "type": "change",
                     "z": "ae673cf6cd8433a0",
                     "name": "März zu Maerz",
                     "rules": [
                         {
                             "t": "change",
                             "p": "datum",
                             "pt": "msg",
                             "from": "März",
                             "fromt": "str",
                             "to": "Maerz",
                             "tot": "str"
                         }
                     ],
                     "action": "",
                     "property": "",
                     "from": "",
                     "to": "",
                     "reg": false,
                     "x": 440,
                     "y": 80,
                     "wires": [
                         [
                             "fc37f5f9d2b0297b"
                         ]
                     ]
                 },
                 {
                     "id": "fc37f5f9d2b0297b",
                     "type": "change",
                     "z": "ae673cf6cd8433a0",
                     "name": "",
                     "rules": [
                         {
                             "t": "set",
                             "p": "topic",
                             "pt": "msg",
                             "to": "\"0_userdata.0.\"  & $env(\"basePath\") & \".\" & datum & \".\" & topic",
                             "tot": "jsonata"
                         }
                     ],
                     "action": "",
                     "property": "",
                     "from": "",
                     "to": "",
                     "reg": false,
                     "x": 660,
                     "y": 80,
                     "wires": [
                         []
                     ]
                 },
                 {
                     "id": "10bd7990f72c7776",
                     "type": "ioBroker out",
                     "z": "5dbdd0fd840b4eee",
                     "name": "",
                     "topic": "",
                     "ack": "true",
                     "autoCreate": "true",
                     "stateName": "",
                     "role": "",
                     "payloadType": "",
                     "readonly": "false",
                     "stateUnit": "",
                     "stateMin": "",
                     "stateMax": "",
                     "x": 2560,
                     "y": 160,
                     "wires": []
                 },
                 {
                     "id": "fbcf46d8f94203aa",
                     "type": "change",
                     "z": "5dbdd0fd840b4eee",
                     "name": "Bezug",
                     "rules": [
                         {
                             "t": "set",
                             "p": "topic",
                             "pt": "msg",
                             "to": "Strombezug",
                             "tot": "str"
                         }
                     ],
                     "action": "",
                     "property": "",
                     "from": "",
                     "to": "",
                     "reg": false,
                     "x": 350,
                     "y": 120,
                     "wires": [
                         [
                             "147888cb9d8dbd57"
                         ]
                     ]
                 },
                 {
                     "id": "a435b3ce1f53ba74",
                     "type": "ioBroker in",
                     "z": "5dbdd0fd840b4eee",
                     "d": true,
                     "name": "Bezug täglich",
                     "attrname": "payload",
                     "topic": "0_userdata.0.Zaehler.Strombezug.Verbrauch.täglich",
                     "payloadType": "value",
                     "onlyack": "",
                     "func": "all",
                     "gap": "",
                     "fireOnStart": "true",
                     "outFormat": "MQTT",
                     "x": 170,
                     "y": 160,
                     "wires": [
                         [
                             "fbcf46d8f94203aa"
                         ]
                     ]
                 },
                 {
                     "id": "779ae42084de3e0c",
                     "type": "inject",
                     "z": "5dbdd0fd840b4eee",
                     "name": "",
                     "props": [
                         {
                             "p": "payload"
                         },
                         {
                             "p": "topic",
                             "vt": "str"
                         }
                     ],
                     "repeat": "",
                     "crontab": "",
                     "once": false,
                     "onceDelay": 0.1,
                     "topic": "Bezug täglich",
                     "payload": "19.1",
                     "payloadType": "num",
                     "x": 170,
                     "y": 120,
                     "wires": [
                         [
                             "fbcf46d8f94203aa"
                         ]
                     ]
                 },
                 {
                     "id": "c097566fbf70cacc",
                     "type": "json",
                     "z": "5dbdd0fd840b4eee",
                     "name": "",
                     "property": "payload",
                     "action": "",
                     "pretty": false,
                     "x": 2390,
                     "y": 160,
                     "wires": [
                         [
                             "10bd7990f72c7776"
                         ]
                     ]
                 },
                 {
                     "id": "6ece1ca957375987",
                     "type": "switch",
                     "z": "5dbdd0fd840b4eee",
                     "name": "topic geändert?",
                     "property": "topic",
                     "propertyType": "msg",
                     "rules": [
                         {
                             "t": "neq",
                             "v": "",
                             "vt": "prev"
                         },
                         {
                             "t": "eq",
                             "v": "",
                             "vt": "prev"
                         }
                     ],
                     "checkall": "true",
                     "repair": false,
                     "outputs": 2,
                     "x": 720,
                     "y": 120,
                     "wires": [
                         [
                             "eaac747b9c1b37da"
                         ],
                         [
                             "102ed68150c3074f"
                         ]
                     ]
                 },
                 {
                     "id": "147888cb9d8dbd57",
                     "type": "subflow:ae673cf6cd8433a0",
                     "z": "5dbdd0fd840b4eee",
                     "name": "",
                     "env": [
                         {
                             "name": "basePath",
                             "value": "Test1.Test5.MonatsTabellen",
                             "type": "str"
                         }
                     ],
                     "x": 520,
                     "y": 120,
                     "wires": [
                         [
                             "6ece1ca957375987"
                         ]
                     ]
                 },
                 {
                     "id": "82c856dec8c7af8d",
                     "type": "ioBroker get",
                     "z": "5dbdd0fd840b4eee",
                     "name": "",
                     "topic": "",
                     "attrname": "payload",
                     "payloadType": "value",
                     "errOnInvalidState": "false",
                     "x": 1260,
                     "y": 80,
                     "wires": [
                         [
                             "95d876ec9e825008"
                         ]
                     ]
                 },
                 {
                     "id": "2672eebe41c3d35a",
                     "type": "json",
                     "z": "5dbdd0fd840b4eee",
                     "name": "",
                     "property": "payload",
                     "action": "",
                     "pretty": false,
                     "x": 1650,
                     "y": 100,
                     "wires": [
                         [
                             "e7b2c3dba88f7574"
                         ]
                     ]
                 },
                 {
                     "id": "95d876ec9e825008",
                     "type": "switch",
                     "z": "5dbdd0fd840b4eee",
                     "name": "IoB read ?",
                     "property": "payload",
                     "propertyType": "msg",
                     "rules": [
                         {
                             "t": "null"
                         },
                         {
                             "t": "nnull"
                         }
                     ],
                     "checkall": "true",
                     "repair": false,
                     "outputs": 2,
                     "x": 1450,
                     "y": 80,
                     "wires": [
                         [
                             "d2e703aaee60b32c"
                         ],
                         [
                             "2672eebe41c3d35a"
                         ]
                     ]
                 },
                 {
                     "id": "d2e703aaee60b32c",
                     "type": "change",
                     "z": "5dbdd0fd840b4eee",
                     "name": "",
                     "rules": [
                         {
                             "t": "set",
                             "p": "payload",
                             "pt": "msg",
                             "to": "[]",
                             "tot": "json"
                         }
                     ],
                     "action": "",
                     "property": "",
                     "from": "",
                     "to": "",
                     "reg": false,
                     "x": 1650,
                     "y": 60,
                     "wires": [
                         [
                             "e7b2c3dba88f7574"
                         ]
                     ]
                 },
                 {
                     "id": "eaac747b9c1b37da",
                     "type": "change",
                     "z": "5dbdd0fd840b4eee",
                     "name": "payload sichern und flow var löschen",
                     "rules": [
                         {
                             "t": "move",
                             "p": "payload",
                             "pt": "msg",
                             "to": "payload_bak",
                             "tot": "msg"
                         },
                         {
                             "t": "delete",
                             "p": "array_bezug",
                             "pt": "flow"
                         }
                     ],
                     "action": "",
                     "property": "",
                     "from": "",
                     "to": "",
                     "reg": false,
                     "x": 990,
                     "y": 80,
                     "wires": [
                         [
                             "82c856dec8c7af8d"
                         ]
                     ]
                 },
                 {
                     "id": "a89ae99abd8609c0",
                     "type": "change",
                     "z": "5dbdd0fd840b4eee",
                     "name": "payload anhängen und sichern",
                     "rules": [
                         {
                             "t": "set",
                             "p": "payload",
                             "pt": "msg",
                             "to": "$append(array_bezug, payload)",
                             "tot": "jsonata"
                         },
                         {
                             "t": "set",
                             "p": "array_bezug",
                             "pt": "flow",
                             "to": "payload",
                             "tot": "msg"
                         }
                     ],
                     "action": "",
                     "property": "",
                     "from": "",
                     "to": "",
                     "reg": false,
                     "x": 2170,
                     "y": 160,
                     "wires": [
                         [
                             "c097566fbf70cacc"
                         ]
                     ]
                 },
                 {
                     "id": "102ed68150c3074f",
                     "type": "change",
                     "z": "5dbdd0fd840b4eee",
                     "name": "",
                     "rules": [
                         {
                             "t": "set",
                             "p": "array_bezug",
                             "pt": "msg",
                             "to": "array_bezug",
                             "tot": "flow"
                         }
                     ],
                     "action": "",
                     "property": "",
                     "from": "",
                     "to": "",
                     "reg": false,
                     "x": 950,
                     "y": 160,
                     "wires": [
                         [
                             "a89ae99abd8609c0"
                         ]
                     ]
                 },
                 {
                     "id": "e7b2c3dba88f7574",
                     "type": "change",
                     "z": "5dbdd0fd840b4eee",
                     "name": "payload wiederherstellen",
                     "rules": [
                         {
                             "t": "move",
                             "p": "payload",
                             "pt": "msg",
                             "to": "array_bezug",
                             "tot": "msg"
                         },
                         {
                             "t": "move",
                             "p": "payload_bak",
                             "pt": "msg",
                             "to": "payload",
                             "tot": "msg"
                         }
                     ],
                     "action": "",
                     "property": "",
                     "from": "",
                     "to": "",
                     "reg": false,
                     "x": 1890,
                     "y": 80,
                     "wires": [
                         [
                             "a89ae99abd8609c0"
                         ]
                     ]
                 }
              ]
              

              und schau, ob Du den verstehst. Ansonsten schaun ich mir Deinen Flow gerne an - aber ich verstehe immer nicht, warum mit JS in NodeRed arbeitet - ich rate Dir immer, die function Nodes wenn möglich immer zu meiden. Für Deine dynamischen Datenpunkte solltest Du es nicht brauchen. Ich habe übrigens mal einen Flow gemacht, den Du Dir auch mal anschauen solltest.

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

                @martybr sagte in Wert in dynamische Struktur im ioBroker ablegen:

                @mickym
                Ich habe hier noch ein Problem, die Zahl der Tage im Monat in eine globale Variable zu schreiben. Statt der 28 Tage aus der Funktion liefert mir der Change Node nur payload == 5

                Bildschirmfoto 2025-02-07 um 08.23.20.png

                [
                    {
                        "id": "f6ed836d74798c7f",
                        "type": "inject",
                        "z": "3ebdbbcf49e0ac40",
                        "name": "",
                        "props": [
                            {
                                "p": "payload"
                            },
                            {
                                "p": "topic",
                                "vt": "str"
                            }
                        ],
                        "repeat": "",
                        "crontab": "",
                        "once": false,
                        "onceDelay": 0.1,
                        "topic": "",
                        "payload": "",
                        "payloadType": "date",
                        "x": 100,
                        "y": 400,
                        "wires": [
                            [
                                "a3434007e702fcdc"
                            ]
                        ]
                    },
                    {
                        "id": "7a09df47bef16411",
                        "type": "function",
                        "z": "3ebdbbcf49e0ac40",
                        "name": "function 1",
                        "func": "// Eingabe: msg.payload sollte ein Datum im Format 'YYYY-MM-DD' sein\nlet inputDate = new Date(msg.payload);\n\n// Hole den Monat und das Jahr\nlet month = inputDate.getMonth(); // 0-11\nlet year = inputDate.getFullYear();\n\n// Berechne die Anzahl der Tage im Monat\nlet daysInMonth = new Date(year, month + 1, 0).getDate();\n\n// Setze das Ergebnis in msg.payload\nmsg.payload = daysInMonth;\n\nreturn msg;",
                        "outputs": 1,
                        "timeout": 0,
                        "noerr": 0,
                        "initialize": "",
                        "finalize": "",
                        "libs": [],
                        "x": 480,
                        "y": 400,
                        "wires": [
                            [
                                "599b66169127c12d",
                                "185c42081279a5e0"
                            ]
                        ]
                    },
                    {
                        "id": "a3434007e702fcdc",
                        "type": "change",
                        "z": "3ebdbbcf49e0ac40",
                        "name": "",
                        "rules": [
                            {
                                "t": "set",
                                "p": "payload",
                                "pt": "msg",
                                "to": "$moment().locale('de').format('YYYY.MM.DD')",
                                "tot": "jsonata"
                            }
                        ],
                        "action": "",
                        "property": "",
                        "from": "",
                        "to": "",
                        "reg": false,
                        "x": 290,
                        "y": 400,
                        "wires": [
                            [
                                "7a09df47bef16411"
                            ]
                        ]
                    },
                    {
                        "id": "d8d647f4ae028cb8",
                        "type": "debug",
                        "z": "3ebdbbcf49e0ac40",
                        "name": "debug 182",
                        "active": true,
                        "tosidebar": true,
                        "console": false,
                        "tostatus": false,
                        "complete": "false",
                        "statusVal": "",
                        "statusType": "auto",
                        "x": 670,
                        "y": 320,
                        "wires": []
                    },
                    {
                        "id": "599b66169127c12d",
                        "type": "change",
                        "z": "3ebdbbcf49e0ac40",
                        "name": "Monatstage",
                        "rules": [
                            {
                                "t": "move",
                                "p": "payload",
                                "pt": "msg",
                                "to": "monatstage",
                                "tot": "global"
                            }
                        ],
                        "action": "",
                        "property": "",
                        "from": "",
                        "to": "",
                        "reg": false,
                        "x": 650,
                        "y": 400,
                        "wires": [
                            [
                                "d8d647f4ae028cb8"
                            ]
                        ]
                    },
                    {
                        "id": "185c42081279a5e0",
                        "type": "debug",
                        "z": "3ebdbbcf49e0ac40",
                        "name": "debug 183",
                        "active": true,
                        "tosidebar": true,
                        "console": false,
                        "tostatus": false,
                        "complete": "false",
                        "statusVal": "",
                        "statusType": "auto",
                        "x": 590,
                        "y": 480,
                        "wires": []
                    }
                ]
                

                Das kann ich leider nicht nachvollziehen, bei mir funktioniert der Flow einwandfrei:

                c55b16d5-fe6b-49ce-b3b7-5cdfca82cca6-image.png

                Ich schau trotzdem mal kurz, ob man das mit $moments direkt erledigen kann.

                M 1 Reply Last reply Reply Quote 0
                • M
                  MartyBr @mickym last edited by

                  @mickym
                  Stimmt, bei mir liefert er nun die richtige Anzahl der Tage.

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

                    @martybr sagte in Wert in dynamische Struktur im ioBroker ablegen:

                    @mickym
                    Stimmt, bei mir liefert er nun die richtige Anzahl der Tage.

                    Ok - dann passt ja alles - ich bin dann erst mal weg - schau dann am Abend nochmal vorbei. Schau Dir mal den neuen Flow - für Deine Arrays und dynam. Datenpunkte derweil an.

                    M 1 Reply Last reply Reply Quote 0
                    • M
                      MartyBr @mickym last edited by

                      @mickym
                      Es sieht alles gut aus. Ich werde mir das genau anschauen und danke dir für deine Hilfe.

                      M 1 Reply Last reply Reply Quote 0
                      • M
                        MartyBr @MartyBr last edited by

                        Ich habe den Flow für die Mittelwertbildung auf den Node aggregate umgestellt.
                        Die Delays dienen der richtigen Reihenfolge der drei Werte min, mean und max im Json. Das ganze wird in einem fortlaufenden Array unter Jahr.Monat abgelegt.

                        Hier der Flow, der zumindest bei mir ohne Fehler erfolgreich läuft.

                        [
                            {
                                "id": "ae673cf6cd8433a0",
                                "type": "subflow",
                                "name": "Datum in Topic",
                                "info": "",
                                "category": "",
                                "in": [
                                    {
                                        "x": 60,
                                        "y": 80,
                                        "wires": [
                                            {
                                                "id": "2e1ea06b2e94bf1a"
                                            }
                                        ]
                                    }
                                ],
                                "out": [
                                    {
                                        "x": 820,
                                        "y": 80,
                                        "wires": [
                                            {
                                                "id": "fc37f5f9d2b0297b",
                                                "port": 0
                                            }
                                        ]
                                    }
                                ],
                                "env": [
                                    {
                                        "name": "basePath",
                                        "type": "str",
                                        "value": "Test1.Test2"
                                    }
                                ],
                                "meta": {},
                                "color": "#DDAA99"
                            },
                            {
                                "id": "2e1ea06b2e94bf1a",
                                "type": "change",
                                "z": "ae673cf6cd8433a0",
                                "name": "",
                                "rules": [
                                    {
                                        "t": "set",
                                        "p": "datum",
                                        "pt": "msg",
                                        "to": "$moment().locale('de').format('YYYY.MMMM')",
                                        "tot": "jsonata"
                                    }
                                ],
                                "action": "",
                                "property": "",
                                "from": "",
                                "to": "",
                                "reg": false,
                                "x": 230,
                                "y": 80,
                                "wires": [
                                    [
                                        "0e8de9437c3c420a"
                                    ]
                                ]
                            },
                            {
                                "id": "0e8de9437c3c420a",
                                "type": "change",
                                "z": "ae673cf6cd8433a0",
                                "name": "März zu Maerz",
                                "rules": [
                                    {
                                        "t": "change",
                                        "p": "datum",
                                        "pt": "msg",
                                        "from": "März",
                                        "fromt": "str",
                                        "to": "Maerz",
                                        "tot": "str"
                                    }
                                ],
                                "action": "",
                                "property": "",
                                "from": "",
                                "to": "",
                                "reg": false,
                                "x": 440,
                                "y": 80,
                                "wires": [
                                    [
                                        "fc37f5f9d2b0297b"
                                    ]
                                ]
                            },
                            {
                                "id": "fc37f5f9d2b0297b",
                                "type": "change",
                                "z": "ae673cf6cd8433a0",
                                "name": "",
                                "rules": [
                                    {
                                        "t": "set",
                                        "p": "topic",
                                        "pt": "msg",
                                        "to": "\"0_userdata.0.\"  & $env(\"basePath\") & \".\" & datum & \".\" & topic",
                                        "tot": "jsonata"
                                    }
                                ],
                                "action": "",
                                "property": "",
                                "from": "",
                                "to": "",
                                "reg": false,
                                "x": 660,
                                "y": 80,
                                "wires": [
                                    []
                                ]
                            },
                            {
                                "id": "8c459eb88d1bf5f1",
                                "type": "tab",
                                "label": "Mittelwert",
                                "disabled": false,
                                "info": "",
                                "env": []
                            },
                            {
                                "id": "9b11db08a1cca5b3",
                                "type": "aggregator",
                                "z": "8c459eb88d1bf5f1",
                                "name": "Mean",
                                "topic": "mean",
                                "intervalCount": "1",
                                "intervalUnits": "d",
                                "submitIncompleteInterval": true,
                                "submitPerTopic": false,
                                "aggregationType": "mean",
                                "x": 290,
                                "y": 260,
                                "wires": [
                                    [
                                        "0290eb1787934b73"
                                    ]
                                ]
                            },
                            {
                                "id": "f33e1d253e22a2dd",
                                "type": "ioBroker in",
                                "z": "8c459eb88d1bf5f1",
                                "name": "Aussentemperatur",
                                "attrname": "payload",
                                "topic": "mqtt.0.vitocal.outside_temperature",
                                "payloadType": "value",
                                "onlyack": "",
                                "func": "all",
                                "gap": "",
                                "fireOnStart": "false",
                                "outFormat": "MQTT",
                                "x": 110,
                                "y": 260,
                                "wires": [
                                    [
                                        "5a18bba8160e8e94",
                                        "9b11db08a1cca5b3",
                                        "32753fd69085ce71"
                                    ]
                                ]
                            },
                            {
                                "id": "5a18bba8160e8e94",
                                "type": "aggregator",
                                "z": "8c459eb88d1bf5f1",
                                "name": "Min",
                                "topic": "min",
                                "intervalCount": "1",
                                "intervalUnits": "d",
                                "submitIncompleteInterval": true,
                                "submitPerTopic": false,
                                "aggregationType": "min",
                                "x": 290,
                                "y": 200,
                                "wires": [
                                    [
                                        "15a56c790ce29f8d"
                                    ]
                                ]
                            },
                            {
                                "id": "32753fd69085ce71",
                                "type": "aggregator",
                                "z": "8c459eb88d1bf5f1",
                                "name": "Max",
                                "topic": "max",
                                "intervalCount": "1",
                                "intervalUnits": "d",
                                "submitIncompleteInterval": true,
                                "submitPerTopic": false,
                                "aggregationType": "max",
                                "x": 290,
                                "y": 320,
                                "wires": [
                                    [
                                        "7a8c3b56e65b5059"
                                    ]
                                ]
                            },
                            {
                                "id": "15a56c790ce29f8d",
                                "type": "join",
                                "z": "8c459eb88d1bf5f1",
                                "name": "",
                                "mode": "custom",
                                "build": "object",
                                "property": "payload",
                                "propertyType": "msg",
                                "key": "topic",
                                "joiner": "\\n",
                                "joinerType": "str",
                                "accumulate": true,
                                "timeout": "60",
                                "count": "3",
                                "reduceRight": false,
                                "reduceExp": "",
                                "reduceInit": "",
                                "reduceInitType": "",
                                "reduceFixup": "",
                                "x": 670,
                                "y": 200,
                                "wires": [
                                    [
                                        "8ef8ee85844f2bb2"
                                    ]
                                ]
                            },
                            {
                                "id": "8ef8ee85844f2bb2",
                                "type": "change",
                                "z": "8c459eb88d1bf5f1",
                                "name": "",
                                "rules": [
                                    {
                                        "t": "set",
                                        "p": "topic",
                                        "pt": "msg",
                                        "to": "meanTmp",
                                        "tot": "str"
                                    }
                                ],
                                "action": "",
                                "property": "",
                                "from": "",
                                "to": "",
                                "reg": false,
                                "x": 840,
                                "y": 200,
                                "wires": [
                                    [
                                        "5d3e4f7dea0efe7c"
                                    ]
                                ]
                            },
                            {
                                "id": "5d3e4f7dea0efe7c",
                                "type": "subflow:ae673cf6cd8433a0",
                                "z": "8c459eb88d1bf5f1",
                                "name": "Datum in Topic",
                                "env": [
                                    {
                                        "name": "basePath",
                                        "value": "Heizung1.MonatsTabellen",
                                        "type": "str"
                                    }
                                ],
                                "x": 1040,
                                "y": 200,
                                "wires": [
                                    [
                                        "9aa634789fccf445"
                                    ]
                                ]
                            },
                            {
                                "id": "e44c746b92947c39",
                                "type": "ioBroker out",
                                "z": "8c459eb88d1bf5f1",
                                "name": "",
                                "topic": "",
                                "ack": "true",
                                "autoCreate": "true",
                                "stateName": "",
                                "role": "",
                                "payloadType": "",
                                "readonly": "false",
                                "stateUnit": "°C",
                                "stateMin": "",
                                "stateMax": "",
                                "x": 2920,
                                "y": 280,
                                "wires": []
                            },
                            {
                                "id": "0290eb1787934b73",
                                "type": "delay",
                                "z": "8c459eb88d1bf5f1",
                                "name": "",
                                "pauseType": "delay",
                                "timeout": "5",
                                "timeoutUnits": "seconds",
                                "rate": "1",
                                "nbRateUnits": "1",
                                "rateUnits": "second",
                                "randomFirst": "1",
                                "randomLast": "5",
                                "randomUnits": "seconds",
                                "drop": false,
                                "allowrate": false,
                                "outputs": 1,
                                "x": 460,
                                "y": 260,
                                "wires": [
                                    [
                                        "15a56c790ce29f8d"
                                    ]
                                ]
                            },
                            {
                                "id": "7a8c3b56e65b5059",
                                "type": "delay",
                                "z": "8c459eb88d1bf5f1",
                                "name": "",
                                "pauseType": "delay",
                                "timeout": "10",
                                "timeoutUnits": "seconds",
                                "rate": "1",
                                "nbRateUnits": "1",
                                "rateUnits": "second",
                                "randomFirst": "1",
                                "randomLast": "5",
                                "randomUnits": "seconds",
                                "drop": false,
                                "allowrate": false,
                                "outputs": 1,
                                "x": 470,
                                "y": 320,
                                "wires": [
                                    [
                                        "15a56c790ce29f8d"
                                    ]
                                ]
                            },
                            {
                                "id": "9aa634789fccf445",
                                "type": "switch",
                                "z": "8c459eb88d1bf5f1",
                                "name": "topic geändert?",
                                "property": "topic",
                                "propertyType": "msg",
                                "rules": [
                                    {
                                        "t": "neq",
                                        "v": "",
                                        "vt": "prev"
                                    },
                                    {
                                        "t": "eq",
                                        "v": "",
                                        "vt": "prev"
                                    }
                                ],
                                "checkall": "true",
                                "repair": false,
                                "outputs": 2,
                                "x": 1240,
                                "y": 200,
                                "wires": [
                                    [
                                        "c7fa49ea854690ed"
                                    ],
                                    [
                                        "edaece611a7db6d5"
                                    ]
                                ]
                            },
                            {
                                "id": "c7fa49ea854690ed",
                                "type": "change",
                                "z": "8c459eb88d1bf5f1",
                                "name": "payload sichern und flow var löschen",
                                "rules": [
                                    {
                                        "t": "move",
                                        "p": "payload",
                                        "pt": "msg",
                                        "to": "payload_bak_mean",
                                        "tot": "msg"
                                    },
                                    {
                                        "t": "delete",
                                        "p": "array_mean",
                                        "pt": "flow"
                                    }
                                ],
                                "action": "",
                                "property": "",
                                "from": "",
                                "to": "",
                                "reg": false,
                                "x": 1530,
                                "y": 180,
                                "wires": [
                                    [
                                        "7fd2bba1daf6d9f3"
                                    ]
                                ]
                            },
                            {
                                "id": "edaece611a7db6d5",
                                "type": "change",
                                "z": "8c459eb88d1bf5f1",
                                "name": "",
                                "rules": [
                                    {
                                        "t": "set",
                                        "p": "array_bezug",
                                        "pt": "msg",
                                        "to": "array_bezug",
                                        "tot": "flow"
                                    }
                                ],
                                "action": "",
                                "property": "",
                                "from": "",
                                "to": "",
                                "reg": false,
                                "x": 1490,
                                "y": 280,
                                "wires": [
                                    [
                                        "515ae9918126f535"
                                    ]
                                ]
                            },
                            {
                                "id": "7fd2bba1daf6d9f3",
                                "type": "ioBroker get",
                                "z": "8c459eb88d1bf5f1",
                                "name": "",
                                "topic": "",
                                "attrname": "payload",
                                "payloadType": "value",
                                "errOnInvalidState": "false",
                                "x": 1800,
                                "y": 180,
                                "wires": [
                                    [
                                        "6e576a4e6d33f548"
                                    ]
                                ]
                            },
                            {
                                "id": "6e576a4e6d33f548",
                                "type": "switch",
                                "z": "8c459eb88d1bf5f1",
                                "name": "IoB read ?",
                                "property": "payload",
                                "propertyType": "msg",
                                "rules": [
                                    {
                                        "t": "null"
                                    },
                                    {
                                        "t": "nnull"
                                    }
                                ],
                                "checkall": "true",
                                "repair": false,
                                "outputs": 2,
                                "x": 2010,
                                "y": 180,
                                "wires": [
                                    [
                                        "ba58ec451fbfa53e"
                                    ],
                                    [
                                        "ae2e0346dd5f3824"
                                    ]
                                ]
                            },
                            {
                                "id": "ba58ec451fbfa53e",
                                "type": "change",
                                "z": "8c459eb88d1bf5f1",
                                "name": "",
                                "rules": [
                                    {
                                        "t": "set",
                                        "p": "payload",
                                        "pt": "msg",
                                        "to": "[]",
                                        "tot": "json"
                                    }
                                ],
                                "action": "",
                                "property": "",
                                "from": "",
                                "to": "",
                                "reg": false,
                                "x": 2250,
                                "y": 160,
                                "wires": [
                                    [
                                        "db03a4ed74093df5"
                                    ]
                                ]
                            },
                            {
                                "id": "ae2e0346dd5f3824",
                                "type": "json",
                                "z": "8c459eb88d1bf5f1",
                                "name": "",
                                "property": "payload",
                                "action": "",
                                "pretty": false,
                                "x": 2230,
                                "y": 220,
                                "wires": [
                                    [
                                        "db03a4ed74093df5"
                                    ]
                                ]
                            },
                            {
                                "id": "db03a4ed74093df5",
                                "type": "change",
                                "z": "8c459eb88d1bf5f1",
                                "name": "payload wiederherstellen",
                                "rules": [
                                    {
                                        "t": "move",
                                        "p": "payload",
                                        "pt": "msg",
                                        "to": "array_mean",
                                        "tot": "msg"
                                    },
                                    {
                                        "t": "move",
                                        "p": "payload_bak_mean",
                                        "pt": "msg",
                                        "to": "payload",
                                        "tot": "msg"
                                    }
                                ],
                                "action": "",
                                "property": "",
                                "from": "",
                                "to": "",
                                "reg": false,
                                "x": 2490,
                                "y": 160,
                                "wires": [
                                    [
                                        "515ae9918126f535"
                                    ]
                                ]
                            },
                            {
                                "id": "515ae9918126f535",
                                "type": "change",
                                "z": "8c459eb88d1bf5f1",
                                "name": "payload anhängen und sichern",
                                "rules": [
                                    {
                                        "t": "set",
                                        "p": "payload",
                                        "pt": "msg",
                                        "to": "$append(array_mean, payload)",
                                        "tot": "jsonata"
                                    },
                                    {
                                        "t": "set",
                                        "p": "array_mean",
                                        "pt": "flow",
                                        "to": "payload",
                                        "tot": "msg"
                                    }
                                ],
                                "action": "",
                                "property": "",
                                "from": "",
                                "to": "",
                                "reg": false,
                                "x": 2510,
                                "y": 280,
                                "wires": [
                                    [
                                        "0427391d23dcb6ad"
                                    ]
                                ]
                            },
                            {
                                "id": "0427391d23dcb6ad",
                                "type": "json",
                                "z": "8c459eb88d1bf5f1",
                                "name": "",
                                "property": "payload",
                                "action": "",
                                "pretty": false,
                                "x": 2750,
                                "y": 280,
                                "wires": [
                                    [
                                        "e44c746b92947c39"
                                    ]
                                ]
                            }
                        ]
                        
                        M 1 Reply Last reply Reply Quote 0
                        • M
                          MartyBr @MartyBr last edited by MartyBr

                          @mickym
                          Ich habe noch eine Frage zu dem u.a. Flow. Ich würde gerne den Payload min, mean und max
                          an die Tagesposition schieben.
                          Also das bedeutet heute (09.02.2025) die 9 Position, das das Element 8.
                          Man könnte doch mit einem Function Node den Code

                          let i ===global.monatstage
                          i = i-1

                          msg.payload[i] = msg.payload[i].state

                          schreiben. Ich habe Monatstage als globale Variable definiert.
                          Mein Problem ist aber im Change node das append. Das widerspricht ja die Nutzung der Function Node.

                          Hast du einen Tipp für mich?

                          EDIT:
                          Ich habe in der Doku gesehen, dass auch in der Change Node mit JSONata mit $sum(payload.state in die Elemente des Arrays geschrieben werden kann.

                          Bildschirmfoto 2025-02-09 um 17.34.27.png

                          Bildschirmfoto 2025-02-09 um 17.34.45.png

                          Bildschirmfoto 2025-02-09 um 17.34.57.png

                          Array Mean:

                          [
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": -4,
                              "mean": 0.05,
                              "max": 3.3
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            },
                            {
                              "min": 0,
                              "mean": 0,
                              "max": 0
                            }
                          ]
                          
                          code_tex[
                              {
                                  "id": "ae673cf6cd8433a0",
                                  "type": "subflow",
                                  "name": "Datum in Topic",
                                  "info": "",
                                  "category": "",
                                  "in": [
                                      {
                                          "x": 60,
                                          "y": 80,
                                          "wires": [
                                              {
                                                  "id": "2e1ea06b2e94bf1a"
                                              }
                                          ]
                                      }
                                  ],
                                  "out": [
                                      {
                                          "x": 820,
                                          "y": 80,
                                          "wires": [
                                              {
                                                  "id": "fc37f5f9d2b0297b",
                                                  "port": 0
                                              }
                                          ]
                                      }
                                  ],
                                  "env": [
                                      {
                                          "name": "basePath",
                                          "type": "str",
                                          "value": "Test1.Test2"
                                      }
                                  ],
                                  "meta": {},
                                  "color": "#DDAA99"
                              },
                              {
                                  "id": "2e1ea06b2e94bf1a",
                                  "type": "change",
                                  "z": "ae673cf6cd8433a0",
                                  "name": "",
                                  "rules": [
                                      {
                                          "t": "set",
                                          "p": "datum",
                                          "pt": "msg",
                                          "to": "$moment().locale('de').format('YYYY.MMMM')",
                                          "tot": "jsonata"
                                      }
                                  ],
                                  "action": "",
                                  "property": "",
                                  "from": "",
                                  "to": "",
                                  "reg": false,
                                  "x": 230,
                                  "y": 80,
                                  "wires": [
                                      [
                                          "0e8de9437c3c420a"
                                      ]
                                  ]
                              },
                              {
                                  "id": "0e8de9437c3c420a",
                                  "type": "change",
                                  "z": "ae673cf6cd8433a0",
                                  "name": "März zu Maerz",
                                  "rules": [
                                      {
                                          "t": "change",
                                          "p": "datum",
                                          "pt": "msg",
                                          "from": "März",
                                          "fromt": "str",
                                          "to": "Maerz",
                                          "tot": "str"
                                      }
                                  ],
                                  "action": "",
                                  "property": "",
                                  "from": "",
                                  "to": "",
                                  "reg": false,
                                  "x": 440,
                                  "y": 80,
                                  "wires": [
                                      [
                                          "fc37f5f9d2b0297b"
                                      ]
                                  ]
                              },
                              {
                                  "id": "fc37f5f9d2b0297b",
                                  "type": "change",
                                  "z": "ae673cf6cd8433a0",
                                  "name": "",
                                  "rules": [
                                      {
                                          "t": "set",
                                          "p": "topic",
                                          "pt": "msg",
                                          "to": "\"0_userdata.0.\"  & $env(\"basePath\") & \".\" & datum & \".\" & topic",
                                          "tot": "jsonata"
                                      }
                                  ],
                                  "action": "",
                                  "property": "",
                                  "from": "",
                                  "to": "",
                                  "reg": false,
                                  "x": 660,
                                  "y": 80,
                                  "wires": [
                                      []
                                  ]
                              },
                              {
                                  "id": "9b11db08a1cca5b3",
                                  "type": "aggregator",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "Mean",
                                  "topic": "mean",
                                  "intervalCount": "1",
                                  "intervalUnits": "h",
                                  "submitIncompleteInterval": true,
                                  "submitPerTopic": false,
                                  "aggregationType": "mean",
                                  "x": 290,
                                  "y": 260,
                                  "wires": [
                                      [
                                          "0290eb1787934b73"
                                      ]
                                  ]
                              },
                              {
                                  "id": "f33e1d253e22a2dd",
                                  "type": "ioBroker in",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "Aussentemperatur",
                                  "attrname": "payload",
                                  "topic": "mqtt.0.vitocal.outside_temperature",
                                  "payloadType": "value",
                                  "onlyack": "",
                                  "func": "all",
                                  "gap": "",
                                  "fireOnStart": "false",
                                  "outFormat": "MQTT",
                                  "x": 110,
                                  "y": 260,
                                  "wires": [
                                      [
                                          "5a18bba8160e8e94",
                                          "9b11db08a1cca5b3",
                                          "32753fd69085ce71"
                                      ]
                                  ]
                              },
                              {
                                  "id": "5a18bba8160e8e94",
                                  "type": "aggregator",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "Min",
                                  "topic": "min",
                                  "intervalCount": "1",
                                  "intervalUnits": "h",
                                  "submitIncompleteInterval": true,
                                  "submitPerTopic": false,
                                  "aggregationType": "min",
                                  "x": 290,
                                  "y": 200,
                                  "wires": [
                                      [
                                          "15a56c790ce29f8d"
                                      ]
                                  ]
                              },
                              {
                                  "id": "32753fd69085ce71",
                                  "type": "aggregator",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "Max",
                                  "topic": "max",
                                  "intervalCount": "1",
                                  "intervalUnits": "h",
                                  "submitIncompleteInterval": true,
                                  "submitPerTopic": false,
                                  "aggregationType": "max",
                                  "x": 290,
                                  "y": 320,
                                  "wires": [
                                      [
                                          "7a8c3b56e65b5059"
                                      ]
                                  ]
                              },
                              {
                                  "id": "15a56c790ce29f8d",
                                  "type": "join",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "",
                                  "mode": "custom",
                                  "build": "object",
                                  "property": "payload",
                                  "propertyType": "msg",
                                  "key": "topic",
                                  "joiner": "\\n",
                                  "joinerType": "str",
                                  "accumulate": true,
                                  "timeout": "60",
                                  "count": "3",
                                  "reduceRight": false,
                                  "reduceExp": "",
                                  "reduceInit": "",
                                  "reduceInitType": "",
                                  "reduceFixup": "",
                                  "x": 670,
                                  "y": 200,
                                  "wires": [
                                      [
                                          "8ef8ee85844f2bb2"
                                      ]
                                  ]
                              },
                              {
                                  "id": "8ef8ee85844f2bb2",
                                  "type": "change",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "",
                                  "rules": [
                                      {
                                          "t": "set",
                                          "p": "topic",
                                          "pt": "msg",
                                          "to": "meanTmp",
                                          "tot": "str"
                                      }
                                  ],
                                  "action": "",
                                  "property": "",
                                  "from": "",
                                  "to": "",
                                  "reg": false,
                                  "x": 840,
                                  "y": 200,
                                  "wires": [
                                      [
                                          "5d3e4f7dea0efe7c"
                                      ]
                                  ]
                              },
                              {
                                  "id": "5d3e4f7dea0efe7c",
                                  "type": "subflow:ae673cf6cd8433a0",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "Datum in Topic",
                                  "env": [
                                      {
                                          "name": "basePath",
                                          "value": "Heizung1.MonatsTabellen",
                                          "type": "str"
                                      }
                                  ],
                                  "x": 1040,
                                  "y": 200,
                                  "wires": [
                                      [
                                          "9aa634789fccf445"
                                      ]
                                  ]
                              },
                              {
                                  "id": "e44c746b92947c39",
                                  "type": "ioBroker out",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "",
                                  "topic": "",
                                  "ack": "true",
                                  "autoCreate": "true",
                                  "stateName": "",
                                  "role": "",
                                  "payloadType": "",
                                  "readonly": "false",
                                  "stateUnit": "°C",
                                  "stateMin": "",
                                  "stateMax": "",
                                  "x": 2920,
                                  "y": 280,
                                  "wires": []
                              },
                              {
                                  "id": "0290eb1787934b73",
                                  "type": "delay",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "",
                                  "pauseType": "delay",
                                  "timeout": "5",
                                  "timeoutUnits": "seconds",
                                  "rate": "1",
                                  "nbRateUnits": "1",
                                  "rateUnits": "second",
                                  "randomFirst": "1",
                                  "randomLast": "5",
                                  "randomUnits": "seconds",
                                  "drop": false,
                                  "allowrate": false,
                                  "outputs": 1,
                                  "x": 460,
                                  "y": 260,
                                  "wires": [
                                      [
                                          "15a56c790ce29f8d"
                                      ]
                                  ]
                              },
                              {
                                  "id": "7a8c3b56e65b5059",
                                  "type": "delay",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "",
                                  "pauseType": "delay",
                                  "timeout": "10",
                                  "timeoutUnits": "seconds",
                                  "rate": "1",
                                  "nbRateUnits": "1",
                                  "rateUnits": "second",
                                  "randomFirst": "1",
                                  "randomLast": "5",
                                  "randomUnits": "seconds",
                                  "drop": false,
                                  "allowrate": false,
                                  "outputs": 1,
                                  "x": 470,
                                  "y": 320,
                                  "wires": [
                                      [
                                          "15a56c790ce29f8d"
                                      ]
                                  ]
                              },
                              {
                                  "id": "9aa634789fccf445",
                                  "type": "switch",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "topic geändert?",
                                  "property": "topic",
                                  "propertyType": "msg",
                                  "rules": [
                                      {
                                          "t": "neq",
                                          "v": "",
                                          "vt": "prev"
                                      },
                                      {
                                          "t": "eq",
                                          "v": "",
                                          "vt": "prev"
                                      }
                                  ],
                                  "checkall": "true",
                                  "repair": false,
                                  "outputs": 2,
                                  "x": 1240,
                                  "y": 200,
                                  "wires": [
                                      [
                                          "c7fa49ea854690ed"
                                      ],
                                      [
                                          "edaece611a7db6d5"
                                      ]
                                  ]
                              },
                              {
                                  "id": "c7fa49ea854690ed",
                                  "type": "change",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "payload sichern und flow var löschen",
                                  "rules": [
                                      {
                                          "t": "move",
                                          "p": "payload",
                                          "pt": "msg",
                                          "to": "payload_bak_mean",
                                          "tot": "msg"
                                      },
                                      {
                                          "t": "delete",
                                          "p": "array_mean",
                                          "pt": "flow"
                                      }
                                  ],
                                  "action": "",
                                  "property": "",
                                  "from": "",
                                  "to": "",
                                  "reg": false,
                                  "x": 1530,
                                  "y": 180,
                                  "wires": [
                                      [
                                          "7fd2bba1daf6d9f3"
                                      ]
                                  ]
                              },
                              {
                                  "id": "edaece611a7db6d5",
                                  "type": "change",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "",
                                  "rules": [
                                      {
                                          "t": "set",
                                          "p": "array_bezug",
                                          "pt": "msg",
                                          "to": "array_bezug",
                                          "tot": "flow"
                                      }
                                  ],
                                  "action": "",
                                  "property": "",
                                  "from": "",
                                  "to": "",
                                  "reg": false,
                                  "x": 1490,
                                  "y": 280,
                                  "wires": [
                                      [
                                          "515ae9918126f535"
                                      ]
                                  ]
                              },
                              {
                                  "id": "7fd2bba1daf6d9f3",
                                  "type": "ioBroker get",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "",
                                  "topic": "",
                                  "attrname": "payload",
                                  "payloadType": "value",
                                  "errOnInvalidState": "false",
                                  "x": 1800,
                                  "y": 180,
                                  "wires": [
                                      [
                                          "6e576a4e6d33f548"
                                      ]
                                  ]
                              },
                              {
                                  "id": "6e576a4e6d33f548",
                                  "type": "switch",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "IoB read ?",
                                  "property": "payload",
                                  "propertyType": "msg",
                                  "rules": [
                                      {
                                          "t": "null"
                                      },
                                      {
                                          "t": "nnull"
                                      }
                                  ],
                                  "checkall": "true",
                                  "repair": false,
                                  "outputs": 2,
                                  "x": 2010,
                                  "y": 180,
                                  "wires": [
                                      [
                                          "ba58ec451fbfa53e"
                                      ],
                                      [
                                          "ae2e0346dd5f3824"
                                      ]
                                  ]
                              },
                              {
                                  "id": "ba58ec451fbfa53e",
                                  "type": "change",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "",
                                  "rules": [
                                      {
                                          "t": "set",
                                          "p": "payload",
                                          "pt": "msg",
                                          "to": "[]",
                                          "tot": "json"
                                      }
                                  ],
                                  "action": "",
                                  "property": "",
                                  "from": "",
                                  "to": "",
                                  "reg": false,
                                  "x": 2250,
                                  "y": 160,
                                  "wires": [
                                      [
                                          "db03a4ed74093df5"
                                      ]
                                  ]
                              },
                              {
                                  "id": "ae2e0346dd5f3824",
                                  "type": "json",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "",
                                  "property": "payload",
                                  "action": "",
                                  "pretty": false,
                                  "x": 2230,
                                  "y": 220,
                                  "wires": [
                                      [
                                          "db03a4ed74093df5"
                                      ]
                                  ]
                              },
                              {
                                  "id": "db03a4ed74093df5",
                                  "type": "change",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "payload wiederherstellen",
                                  "rules": [
                                      {
                                          "t": "move",
                                          "p": "payload",
                                          "pt": "msg",
                                          "to": "array_mean",
                                          "tot": "msg"
                                      },
                                      {
                                          "t": "move",
                                          "p": "payload_bak_mean",
                                          "pt": "msg",
                                          "to": "payload",
                                          "tot": "msg"
                                      }
                                  ],
                                  "action": "",
                                  "property": "",
                                  "from": "",
                                  "to": "",
                                  "reg": false,
                                  "x": 2490,
                                  "y": 160,
                                  "wires": [
                                      [
                                          "515ae9918126f535"
                                      ]
                                  ]
                              },
                              {
                                  "id": "515ae9918126f535",
                                  "type": "change",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "payload anhängen und sichern",
                                  "rules": [
                                      {
                                          "t": "set",
                                          "p": "payload",
                                          "pt": "msg",
                                          "to": "$append(array_mean, payload)",
                                          "tot": "jsonata"
                                      },
                                      {
                                          "t": "set",
                                          "p": "array_mean",
                                          "pt": "flow",
                                          "to": "payload",
                                          "tot": "msg"
                                      }
                                  ],
                                  "action": "",
                                  "property": "",
                                  "from": "",
                                  "to": "",
                                  "reg": false,
                                  "x": 2510,
                                  "y": 280,
                                  "wires": [
                                      [
                                          "0427391d23dcb6ad"
                                      ]
                                  ]
                              },
                              {
                                  "id": "0427391d23dcb6ad",
                                  "type": "json",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "",
                                  "property": "payload",
                                  "action": "",
                                  "pretty": false,
                                  "x": 2750,
                                  "y": 280,
                                  "wires": [
                                      [
                                          "e44c746b92947c39"
                                      ]
                                  ]
                              },
                              {
                                  "id": "809efb6124c3639c",
                                  "type": "change",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "",
                                  "rules": [
                                      {
                                          "t": "set",
                                          "p": "payload",
                                          "pt": "msg",
                                          "to": "$moment().date()",
                                          "tot": "jsonata"
                                      },
                                      {
                                          "t": "set",
                                          "p": "payload",
                                          "pt": "msg",
                                          "to": "monatstage",
                                          "tot": "global"
                                      }
                                  ],
                                  "action": "",
                                  "property": "",
                                  "from": "",
                                  "to": "",
                                  "reg": false,
                                  "x": 290,
                                  "y": 460,
                                  "wires": [
                                      [
                                          "a27f09da64977051"
                                      ]
                                  ]
                              },
                              {
                                  "id": "02c66f19b70ff804",
                                  "type": "inject",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "",
                                  "props": [
                                      {
                                          "p": "payload"
                                      },
                                      {
                                          "p": "topic",
                                          "vt": "str"
                                      }
                                  ],
                                  "repeat": "300",
                                  "crontab": "",
                                  "once": false,
                                  "onceDelay": 0.1,
                                  "topic": "",
                                  "payload": "",
                                  "payloadType": "date",
                                  "x": 110,
                                  "y": 460,
                                  "wires": [
                                      [
                                          "809efb6124c3639c"
                                      ]
                                  ]
                              },
                              {
                                  "id": "a27f09da64977051",
                                  "type": "debug",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "Datum",
                                  "active": true,
                                  "tosidebar": true,
                                  "console": false,
                                  "tostatus": false,
                                  "complete": "payload",
                                  "targetType": "msg",
                                  "statusVal": "",
                                  "statusType": "auto",
                                  "x": 470,
                                  "y": 460,
                                  "wires": []
                              },
                              {
                                  "id": "be82df1e7a1f3571",
                                  "type": "change",
                                  "z": "8c459eb88d1bf5f1",
                                  "name": "payload anhängen und sichern",
                                  "rules": [
                                      {
                                          "t": "set",
                                          "p": "payload",
                                          "pt": "msg",
                                          "to": "$append(array_mean, payload)",
                                          "tot": "jsonata"
                                      },
                                      {
                                          "t": "set",
                                          "p": "array_mean",
                                          "pt": "flow",
                                          "to": "payload",
                                          "tot": "msg"
                                      }
                                  ],
                                  "action": "",
                                  "property": "",
                                  "from": "",
                                  "to": "",
                                  "reg": false,
                                  "x": 2470,
                                  "y": 380,
                                  "wires": [
                                      []
                                  ]
                              }
                          ]t
                          
                          1 Reply Last reply Reply Quote 0
                          • mickym
                            mickym Most Active last edited by

                            du brauchst keine monatstage etc. du hast doch ein Array und da bildest du einfach den durchschnitt der werte. das Array wid doch jeden monat neu geschrieben

                            M 1 Reply Last reply Reply Quote 0
                            • M
                              MartyBr @mickym last edited by

                              @mickym
                              Ich dachte mir das nur als Fallback, wenn iobroker / Node-red mal steht und ein Tag übersprungen wird.

                              So klappt es wunderbar und ich fuchse mich so langsam in die Materie ein.

                              M mickym 2 Replies Last reply Reply Quote 0
                              • M
                                MartyBr @MartyBr last edited by

                                @mickym
                                Ich sehe gerade den Read IOB Baustein. Liesst dieser die Anzahl der Elemente im Array ein? Ich sehe hier keine Einstellungen oder Code.

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

                                  @martybr aber gerade wenn ein Tag übersprungen wird, ist es doch sinnvoller den Durschnitt der real gemessenen Werte zu nehmen.

                                  1 Reply Last reply Reply Quote 0
                                  • M
                                    MartyBr last edited by

                                    @mickym
                                    In meinem Anwendungsfall setze ich die täglichen Temperaturen im Verhältnis zu den Heizungsverbräuchen, also mehr Stromverbrauch der Wärmepumpe bei niedrigeren Außentemperaturen.
                                    Das dient daher zur Einschätzung der Effektivität der Wärmepumpe.

                                    Ich hoffe, ich habe hier meinen Ansatz erklären können 🤓

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

                                      @martybr sagte in Wert in dynamische Struktur im ioBroker ablegen:

                                      @mickym
                                      In meinem Anwendungsfall setze ich die täglichen Temperaturen im Verhältnis zu den Heizungsverbräuchen, also mehr Stromverbrauch der Wärmepumpe bei niedrigeren Außentemperaturen.
                                      Das dient daher zur Einschätzung der Effektivität der Wärmepumpe.

                                      Ich hoffe, ich habe hier meinen Ansatz erklären können 🤓

                                      na eben, dann ist es doch sinnvoller, wenn deine Arrays sich aus Tageswerten zusammensetzt, davon den Durchschnitt zu nehmen, als durch eine fixe theoretische Anzahl an Tagen. Sprich Dein Array enthält nur 26 Werte im Februar- dann ist es doch sinnvoller den Durchschnitt aus 26 Werten zu nehmen, als die Summe durch 28 zu teilen.

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

                                        ja aner mach wie du denkst. ja mit Jsonata kannst du Durchnitt, Summen etc. über Arrays bilden.

                                        am einfachsten ist es dann wenn du das Array in einen Datenpunkt schreibst auch gleich die aggregierten Werte in entsprechende Datenpunkte zu schreiben

                                        M 1 Reply Last reply Reply Quote 0
                                        • M
                                          MartyBr @mickym last edited by

                                          @mickym
                                          Kannst du mir die Syntax nennen? Wie schreibe ich mit JSONata in ein Element des Array?
                                          Ich mache mich dann an die Arbeit.
                                          Die täglichen Temperaturwerte habe ich ja im Flow. Ich muss sie dann mit save payload.state [i] an die richtige Stelle schreiben.

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

                                            @martybr na wenn du ein Array in deiner payload bereits hast, dann halt payload[index]
                                            das Element muss aber schon existieren

                                            120bbbdc-92a8-4c9c-ae11-74d0c773efb0-image.png

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            1.2k
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

                                            2
                                            91
                                            4041
                                            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