Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

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

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Node-Red
  5. Gelöst: Wert in dynamische Struktur im ioBroker ablegen

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.8k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.2k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.4k

Gelöst: Wert in dynamische Struktur im ioBroker ablegen

Geplant Angeheftet Gesperrt Verschoben Node-Red
91 Beiträge 2 Kommentatoren 9.3k Aufrufe 2 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • M MartyBr

    @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 :innocent:

    mickymM Offline
    mickymM Offline
    mickym
    Most Active
    schrieb am zuletzt editiert von
    #39

    @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.

    Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

    1 Antwort Letzte Antwort
    1
    • M MartyBr

      @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": []
          }
      ]
      
      mickymM Offline
      mickymM Offline
      mickym
      Most Active
      schrieb am zuletzt editiert von
      #40

      @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.

      Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

      M 1 Antwort Letzte Antwort
      0
      • mickymM mickym

        @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 Offline
        M Offline
        MartyBr
        schrieb am zuletzt editiert von
        #41

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

        Gruß
        Martin


        Intel NUCs mit Proxmox / Iobroker als VM unter Debian
        Raspeberry mit USB Leseköpfen für Smartmeter
        Homematic und Homematic IP

        mickymM 1 Antwort Letzte Antwort
        0
        • M MartyBr

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

          mickymM Offline
          mickymM Offline
          mickym
          Most Active
          schrieb am zuletzt editiert von
          #42

          @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.

          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

          M 1 Antwort Letzte Antwort
          0
          • mickymM mickym

            @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 Offline
            M Offline
            MartyBr
            schrieb am zuletzt editiert von
            #43

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

            Gruß
            Martin


            Intel NUCs mit Proxmox / Iobroker als VM unter Debian
            Raspeberry mit USB Leseköpfen für Smartmeter
            Homematic und Homematic IP

            M 1 Antwort Letzte Antwort
            0
            • M MartyBr

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

              M Offline
              M Offline
              MartyBr
              schrieb am zuletzt editiert von
              #44

              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"
                          ]
                      ]
                  }
              ]
              

              Gruß
              Martin


              Intel NUCs mit Proxmox / Iobroker als VM unter Debian
              Raspeberry mit USB Leseköpfen für Smartmeter
              Homematic und Homematic IP

              M 1 Antwort Letzte Antwort
              0
              • M MartyBr

                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 Offline
                M Offline
                MartyBr
                schrieb am zuletzt editiert von MartyBr
                #45

                @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
                

                Gruß
                Martin


                Intel NUCs mit Proxmox / Iobroker als VM unter Debian
                Raspeberry mit USB Leseköpfen für Smartmeter
                Homematic und Homematic IP

                1 Antwort Letzte Antwort
                0
                • mickymM Offline
                  mickymM Offline
                  mickym
                  Most Active
                  schrieb am zuletzt editiert von
                  #46

                  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

                  Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                  M 1 Antwort Letzte Antwort
                  0
                  • mickymM mickym

                    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 Offline
                    M Offline
                    MartyBr
                    schrieb am zuletzt editiert von
                    #47

                    @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.

                    Gruß
                    Martin


                    Intel NUCs mit Proxmox / Iobroker als VM unter Debian
                    Raspeberry mit USB Leseköpfen für Smartmeter
                    Homematic und Homematic IP

                    M mickymM 2 Antworten Letzte Antwort
                    0
                    • M MartyBr

                      @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 Offline
                      M Offline
                      MartyBr
                      schrieb am zuletzt editiert von
                      #48

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

                      Gruß
                      Martin


                      Intel NUCs mit Proxmox / Iobroker als VM unter Debian
                      Raspeberry mit USB Leseköpfen für Smartmeter
                      Homematic und Homematic IP

                      1 Antwort Letzte Antwort
                      0
                      • M MartyBr

                        @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.

                        mickymM Offline
                        mickymM Offline
                        mickym
                        Most Active
                        schrieb am zuletzt editiert von mickym
                        #49

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

                        Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                        1 Antwort Letzte Antwort
                        0
                        • M Offline
                          M Offline
                          MartyBr
                          schrieb am zuletzt editiert von
                          #50

                          @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 :nerd_face:

                          Gruß
                          Martin


                          Intel NUCs mit Proxmox / Iobroker als VM unter Debian
                          Raspeberry mit USB Leseköpfen für Smartmeter
                          Homematic und Homematic IP

                          mickymM 1 Antwort Letzte Antwort
                          0
                          • M MartyBr

                            @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 :nerd_face:

                            mickymM Offline
                            mickymM Offline
                            mickym
                            Most Active
                            schrieb am zuletzt editiert von
                            #51

                            @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 :nerd_face:

                            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.

                            Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                            1 Antwort Letzte Antwort
                            0
                            • mickymM Offline
                              mickymM Offline
                              mickym
                              Most Active
                              schrieb am zuletzt editiert von mickym
                              #52

                              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

                              Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                              M 1 Antwort Letzte Antwort
                              0
                              • mickymM 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 Offline
                                M Offline
                                MartyBr
                                schrieb am zuletzt editiert von
                                #53

                                @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.

                                Gruß
                                Martin


                                Intel NUCs mit Proxmox / Iobroker als VM unter Debian
                                Raspeberry mit USB Leseköpfen für Smartmeter
                                Homematic und Homematic IP

                                mickymM 2 Antworten Letzte Antwort
                                0
                                • M MartyBr

                                  @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.

                                  mickymM Offline
                                  mickymM Offline
                                  mickym
                                  Most Active
                                  schrieb am zuletzt editiert von mickym
                                  #54

                                  @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

                                  Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                  1 Antwort Letzte Antwort
                                  0
                                  • M MartyBr

                                    @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.

                                    mickymM Offline
                                    mickymM Offline
                                    mickym
                                    Most Active
                                    schrieb am zuletzt editiert von
                                    #55

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

                                    Die täglichen Temperaturwerte habe ich ja im Flow. Ich muss sie dann mit save payload.state [i] an die richtige Stelle schreiben.

                                    Warum das denn? - Die werden doch jeden Tag einfach hinten angehängt

                                    Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                    M 1 Antwort Letzte Antwort
                                    0
                                    • mickymM mickym

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

                                      Die täglichen Temperaturwerte habe ich ja im Flow. Ich muss sie dann mit save payload.state [i] an die richtige Stelle schreiben.

                                      Warum das denn? - Die werden doch jeden Tag einfach hinten angehängt

                                      M Offline
                                      M Offline
                                      MartyBr
                                      schrieb am zuletzt editiert von
                                      #56

                                      @mickym
                                      Im Normalfall ist das die optimale Lösung. Ich habe den Fall betrachtet, wenn das System Nachts steht und somit der eine Wert nicht generiert wird. In der nächsten Nacht wird dann ein neuer Wert an die Position des ausgefallenen geschrieben. Das ist nicht Systemkritisch, stört mich einfach, weil der Wert für den entsprechenden Tag nicht stimmt.

                                      Das scheint aber ein diffiziles Problem zu sein. Aktuell bekomme ich nur Fehler.

                                      Gruß
                                      Martin


                                      Intel NUCs mit Proxmox / Iobroker als VM unter Debian
                                      Raspeberry mit USB Leseköpfen für Smartmeter
                                      Homematic und Homematic IP

                                      mickymM 1 Antwort Letzte Antwort
                                      0
                                      • M MartyBr

                                        @mickym
                                        Im Normalfall ist das die optimale Lösung. Ich habe den Fall betrachtet, wenn das System Nachts steht und somit der eine Wert nicht generiert wird. In der nächsten Nacht wird dann ein neuer Wert an die Position des ausgefallenen geschrieben. Das ist nicht Systemkritisch, stört mich einfach, weil der Wert für den entsprechenden Tag nicht stimmt.

                                        Das scheint aber ein diffiziles Problem zu sein. Aktuell bekomme ich nur Fehler.

                                        mickymM Offline
                                        mickymM Offline
                                        mickym
                                        Most Active
                                        schrieb am zuletzt editiert von
                                        #57

                                        @martybr Wie gesagt - ich würde die Position eines Arrays nicht mit einem bestimmten Tag verknüpfen. Sonst hast Du Lücken und das macht alles kompliziert

                                        Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                        M 1 Antwort Letzte Antwort
                                        0
                                        • mickymM mickym

                                          @martybr Wie gesagt - ich würde die Position eines Arrays nicht mit einem bestimmten Tag verknüpfen. Sonst hast Du Lücken und das macht alles kompliziert

                                          M Offline
                                          M Offline
                                          MartyBr
                                          schrieb am zuletzt editiert von
                                          #58

                                          @mickym
                                          Ich habe aber ansonsten das Problem, dass ich die Temperaturwerte nicht mit den Heizungswerten verknüpfen kann. Auch die Heizungswerte laufen in Arrays Tagesgenau ein.
                                          Leider bisher aber in Javascript. Ich versuche ja mit deiner Hilfe die "Programme" in Node-Red umzusetzen.
                                          Ich habe hier schöne Grafiken, die diese Werte Temperatur Tag x mit dem Energiewert Tag x anzeigen.
                                          Ich halte die Tagesgenaue Speicherung zu absolut notwendig. Aktuell läuft es mit dem append. Ein Problem tritt ja nur bei einem Serverausfall auf.

                                          Gruß
                                          Martin


                                          Intel NUCs mit Proxmox / Iobroker als VM unter Debian
                                          Raspeberry mit USB Leseköpfen für Smartmeter
                                          Homematic und Homematic IP

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


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          394

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

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

                                          • Du hast noch kein Konto? Registrieren

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