Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. Visualisierung mit Node Red erstellen

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Visualisierung mit Node Red erstellen

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

      @damrak2022 Du sollst nichts rechnen. Wenn Du ein Array mit Objekten hast, dann machst Du das alles mit JSONATA.

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

        @mickym Mein Flow und meine Influx node sehen so aus:
        Bildschirm­foto 2023-01-24 um 05.39.14.png Bildschirm­foto 2023-01-24 um 05.38.58.png
        Wenn ich das Teile die Werte durch 1000 in der InfluxDB node eingebe, kann ich mir doch die Change Nodes sparen, oder sehe ich das falsch?

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

          @damrak2022 Na wenn Du das kannst ist ja OK. Ich glaub Dir erst wenn ich das Array mit den Objekten aus der Influx DB sehe.

          Dann musst Du die Objekte in folgende Form bringen, wie auf dieser Webseite beschrieben: https://stevesnoderedguide.com/using-the-node-red-chart-node

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

            @mickym Okay, ich lese mir das nochmal durch.

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

              @damrak2022 Ansonsten zeig halt mal ob da ein Array mit Objekten aus Deiner Abfrage raus kommt. Wie kannst Du irgendwelche Nodes oder Flows machen, wenn Du gar nicht weisst, ob Deine Abfrage funktioniert?

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

                @mickym Die Werte bekomme ich im Debug:
                Bildschirm­foto 2023-01-24 um 05.49.23.png Bildschirm­foto 2023-01-24 um 05.49.04.png

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

                  @damrak2022 Na dann musst Du mit JSONATA nun das alles so ummodeln, dass Du die 3 Serien von Datenpunkten hast, wie in derm Artikel für Linienchart beschrieben ist.

                  867c7b8c-acde-4b32-9d59-9a4cc92f8375-image.png

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

                    @mickym Ich werde versuchen, ob ich hier weiterkomme, ansonsten frage ich Dich ob wir das heute Abend evtl. mal angehen könnten?

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

                      @mickym Ich habe das jetzt in der Influx Node so konfiguriert, das ich im Debug die korrekten Werte erhalte:
                      Bildschirm­foto 2023-01-26 um 01.36.19.png Bildschirm­foto 2023-01-26 um 01.35.54.png

                      Allerdings muss ich gestehen das ich irgendwie keine Ahnung habe, wie ich jetzt weitermachen muss um die Daten in der Chart Node im Liniendiagramm darzustellen.

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

                        @damrak2022 Na ich habs Dir ja gepostet. Du kannst ja mal alles was aus der Debug Node rauskommt hier in Code-Tags einstellen. Dann kann mit den Daten über eine Inject Node selbst bissi rumprobieren. Aber ich mach das je nachdem, wie ich lustig bin, also brauchst erst mal nicht drauf zu warten.

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

                          @mickym Das ist die Debug Ausgabe:

                          array[12]
                          [0 … 9]
                          0: object
                          result: "_result"
                          table: 0
                          _start: "2023-01-19T00:35:58.94679632Z"
                          _stop: "2023-01-26T00:35:58.94679632Z"
                          _time: "2023-01-23T05:50:55.302Z"
                          _value: 84
                          _field: "value"
                          _measurement: "Diastole"
                          1: object
                          result: "_result"
                          table: 0
                          _start: "2023-01-19T00:35:58.94679632Z"
                          _stop: "2023-01-26T00:35:58.94679632Z"
                          _time: "2023-01-23T06:07:26.39Z"
                          _value: 78
                          _field: "value"
                          _measurement: "Diastole"
                          2: object
                          result: "_result"
                          table: 0
                          _start: "2023-01-19T00:35:58.94679632Z"
                          _stop: "2023-01-26T00:35:58.94679632Z"
                          _time: "2023-01-24T07:07:26.438Z"
                          _value: 78
                          _field: "value"
                          _measurement: "Diastole"
                          3: object
                          result: "_result"
                          table: 0
                          _start: "2023-01-19T00:35:58.94679632Z"
                          _stop: "2023-01-26T00:35:58.94679632Z"
                          _time: "2023-01-24T07:22:26.52Z"
                          _value: 71
                          _field: "value"
                          _measurement: "Diastole"
                          4: object
                          result: "_result"
                          table: 1
                          _start: "2023-01-19T00:35:58.94679632Z"
                          _stop: "2023-01-26T00:35:58.94679632Z"
                          _time: "2023-01-23T05:51:28.093Z"
                          _value: 114
                          _field: "value"
                          _measurement: "Puls"
                          5: object
                          result: "_result"
                          table: 1
                          _start: "2023-01-19T00:35:58.94679632Z"
                          _stop: "2023-01-26T00:35:58.94679632Z"
                          _time: "2023-01-23T06:07:26.392Z"
                          _value: 106
                          _field: "value"
                          _measurement: "Puls"
                          6: object
                          result: "_result"
                          table: 1
                          _start: "2023-01-19T00:35:58.94679632Z"
                          _stop: "2023-01-26T00:35:58.94679632Z"
                          _time: "2023-01-24T07:07:26.442Z"
                          _value: 106
                          _field: "value"
                          _measurement: "Puls"
                          7: object
                          result: "_result"
                          table: 1
                          _start: "2023-01-19T00:35:58.94679632Z"
                          _stop: "2023-01-26T00:35:58.94679632Z"
                          _time: "2023-01-24T07:22:26.521Z"
                          _value: 85
                          _field: "value"
                          _measurement: "Puls"
                          8: object
                          result: "_result"
                          table: 2
                          _start: "2023-01-19T00:35:58.94679632Z"
                          _stop: "2023-01-26T00:35:58.94679632Z"
                          _time: "2023-01-23T05:50:25.342Z"
                          _value: 127
                          _field: "value"
                          _measurement: "Systole"
                          9: object
                          result: "_result"
                          table: 2
                          _start: "2023-01-19T00:35:58.94679632Z"
                          _stop: "2023-01-26T00:35:58.94679632Z"
                          _time: "2023-01-23T06:07:26.39Z"
                          _value: 114
                          _field: "value"
                          _measurement: "Systole"
                          [10 … 11]
                          10: object
                          result: "_result"
                          table: 2
                          _start: "2023-01-19T00:35:58.94679632Z"
                          _stop: "2023-01-26T00:35:58.94679632Z"
                          _time: "2023-01-24T07:07:26.439Z"
                          _value: 114
                          _field: "value"
                          _measurement: "Systole"
                          11: object
                          result: "_result"
                          table: 2
                          _start: "2023-01-19T00:35:58.94679632Z"
                          _stop: "2023-01-26T00:35:58.94679632Z"
                          _time: "2023-01-24T07:22:26.521Z"
                          _value: 107
                          _field: "value"
                          _measurement: "Systole"
                          
                          
                          mickym 1 Reply Last reply Reply Quote 0
                          • mickym
                            mickym Most Active @Damrak2022 last edited by mickym

                            @damrak2022 Nein nicht so. Den Wert sauber aus dem Debug Fenster kopieren - nicht mit der Maus. Das solltest Du eigentlich wissen - wie soll ich das denn bitte in eine Inject Node bringen - das ist doch kein Objekt und kein Array.

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

                              @mickym Meinst Du so?

                              payload[10]._value
                              

                              Das ist die Systole

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

                                @damrak2022 Nein Du sollst den Wert aus dem Debug-Fenster kopieren, der aus der Debug Node rauskommt - aber ganz oben, wie man das sauber macht mit "Wert kopieren".

                                copy path.gif

                                Ich hab das Gefühl - wir fangen wieder bei NULL an.

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

                                  @mickym

                                  {"result":"_result","table":0,"_start":"2023-01-19T00:35:58.94679632Z","_stop":"2023-01-26T00:35:58.94679632Z","_time":"2023-01-23T05:50:55.302Z","_value":84,"_field":"value","_measurement":"Diastole"}
                                  

                                  Sorry, stehe gerade völlig auf dem Schlauch.

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

                                    @damrak2022 Das ist doch nur ein Objekt - aber schon besser.

                                    72cbbd8d-748b-419f-b41f-7b9020fccaff-image.png

                                    Du kannst doch mit der Maus ganz oben den Wert kopieren, sodass das ganze Array enthalten ist.

                                    aec60912-f6e8-4344-8602-6f8d85945df6-image.png

                                    Also direkt mit der Maus in die Zeile wo array[12] stehen und den Wert kopieren. Ich dachte eigentlich, dass Du das weißt, wie man in dem Debug Fenster Pfade und Werte kopierst.

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

                                      @mickym

                                      [{"result":"_result","table":0,"_start":"2023-01-19T00:35:58.94679632Z","_stop":"2023-01-26T00:35:58.94679632Z","_time":"2023-01-23T05:50:55.302Z","_value":84,"_field":"value","_measurement":"Diastole"},{"result":"_result","table":0,"_start":"2023-01-19T00:35:58.94679632Z","_stop":"2023-01-26T00:35:58.94679632Z","_time":"2023-01-23T06:07:26.39Z","_value":78,"_field":"value","_measurement":"Diastole"},{"result":"_result","table":0,"_start":"2023-01-19T00:35:58.94679632Z","_stop":"2023-01-26T00:35:58.94679632Z","_time":"2023-01-24T07:07:26.438Z","_value":78,"_field":"value","_measurement":"Diastole"},{"result":"_result","table":0,"_start":"2023-01-19T00:35:58.94679632Z","_stop":"2023-01-26T00:35:58.94679632Z","_time":"2023-01-24T07:22:26.52Z","_value":71,"_field":"value","_measurement":"Diastole"},{"result":"_result","table":1,"_start":"2023-01-19T00:35:58.94679632Z","_stop":"2023-01-26T00:35:58.94679632Z","_time":"2023-01-23T05:51:28.093Z","_value":114,"_field":"value","_measurement":"Puls"},{"result":"_result","table":1,"_start":"2023-01-19T00:35:58.94679632Z","_stop":"2023-01-26T00:35:58.94679632Z","_time":"2023-01-23T06:07:26.392Z","_value":106,"_field":"value","_measurement":"Puls"},{"result":"_result","table":1,"_start":"2023-01-19T00:35:58.94679632Z","_stop":"2023-01-26T00:35:58.94679632Z","_time":"2023-01-24T07:07:26.442Z","_value":106,"_field":"value","_measurement":"Puls"},{"result":"_result","table":1,"_start":"2023-01-19T00:35:58.94679632Z","_stop":"2023-01-26T00:35:58.94679632Z","_time":"2023-01-24T07:22:26.521Z","_value":85,"_field":"value","_measurement":"Puls"},{"result":"_result","table":2,"_start":"2023-01-19T00:35:58.94679632Z","_stop":"2023-01-26T00:35:58.94679632Z","_time":"2023-01-23T05:50:25.342Z","_value":127,"_field":"value","_measurement":"Systole"},{"result":"_result","table":2,"_start":"2023-01-19T00:35:58.94679632Z","_stop":"2023-01-26T00:35:58.94679632Z","_time":"2023-01-23T06:07:26.39Z","_value":114,"_field":"value","_measurement":"Systole"},{"result":"_result","table":2,"_start":"2023-01-19T00:35:58.94679632Z","_stop":"2023-01-26T00:35:58.94679632Z","_time":"2023-01-24T07:07:26.439Z","_value":114,"_field":"value","_measurement":"Systole"},{"result":"_result","table":2,"_start":"2023-01-19T00:35:58.94679632Z","_stop":"2023-01-26T00:35:58.94679632Z","_time":"2023-01-24T07:22:26.521Z","_value":107,"_field":"value","_measurement":"Systole"}]
                                      
                                      mickym 2 Replies Last reply Reply Quote 0
                                      • mickym
                                        mickym Most Active @Damrak2022 last edited by

                                        @damrak2022 Sehr gut! 👍 👍

                                        Nun kann ich mit den gleichen Daten selbst rumprobieren:

                                        4e0b827f-f3a0-4e91-8f75-be9b447260d1-image.png

                                        So was sollte aber inzwischen selbstverständlich sein. 😉 - Also Danke!

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

                                          @damrak2022 So ich habs fertig - grundsätzlich gilt, dass das Auslesen der Daten aus der Influx DB nur zum Initialisieren des Charts dient - weitere Werte lässt Du direkt in die Chart Node wandern.

                                          Also die DB Abfrage nur einmal machen - wenn der Flow neu gestartet wird.

                                          9f8e5220-80ea-4cf5-9180-55c0e2e74cf8-image.png

                                          Löschen kann man die Chart Node in dem man ihr wie in der ersten Node ein leeres Array übergibt.

                                          Sprich die Inject Nodes mit Diastole etc. da müssen dann direkt die Datenpunkte über die iobroker IN Node davor und Du musst das topic setzen wie in den Inject-Nodes vorgegeben.

                                          Die Influx-DB Abfrage machst Du nur einmal beim Neustart des NodeRed Adapters - also einfach einmalig mit einer Inject Node die Query machen und dann in die von mir erstelle Change Node verbinden.

                                          Und wenn Du das JSONATA so gut verstehst, was ich da drin gemacht habe - dann können wir solche Aufgaben machen. Aber da muss ich selbst rumprobieren und ich glaube, dass Du da noch so weit entfernt bist (Lichtjahre 😁 ), dass wir uns da entsprechend austauschen könnten.

                                          [
                                             {
                                                 "id": "e79f1c62ef97b36a",
                                                 "type": "inject",
                                                 "z": "1983aa28392732ca",
                                                 "name": "Influx DB Abfrage zur Initialisierung",
                                                 "props": [
                                                     {
                                                         "p": "payload"
                                                     }
                                                 ],
                                                 "repeat": "",
                                                 "crontab": "",
                                                 "once": false,
                                                 "onceDelay": 0.1,
                                                 "topic": "",
                                                 "payload": "[{\"result\":\"_result\",\"table\":0,\"_start\":\"2023-01-19T00:35:58.94679632Z\",\"_stop\":\"2023-01-26T00:35:58.94679632Z\",\"_time\":\"2023-01-23T05:50:55.302Z\",\"_value\":84,\"_field\":\"value\",\"_measurement\":\"Diastole\"},{\"result\":\"_result\",\"table\":0,\"_start\":\"2023-01-19T00:35:58.94679632Z\",\"_stop\":\"2023-01-26T00:35:58.94679632Z\",\"_time\":\"2023-01-23T06:07:26.39Z\",\"_value\":78,\"_field\":\"value\",\"_measurement\":\"Diastole\"},{\"result\":\"_result\",\"table\":0,\"_start\":\"2023-01-19T00:35:58.94679632Z\",\"_stop\":\"2023-01-26T00:35:58.94679632Z\",\"_time\":\"2023-01-24T07:07:26.438Z\",\"_value\":78,\"_field\":\"value\",\"_measurement\":\"Diastole\"},{\"result\":\"_result\",\"table\":0,\"_start\":\"2023-01-19T00:35:58.94679632Z\",\"_stop\":\"2023-01-26T00:35:58.94679632Z\",\"_time\":\"2023-01-24T07:22:26.52Z\",\"_value\":71,\"_field\":\"value\",\"_measurement\":\"Diastole\"},{\"result\":\"_result\",\"table\":1,\"_start\":\"2023-01-19T00:35:58.94679632Z\",\"_stop\":\"2023-01-26T00:35:58.94679632Z\",\"_time\":\"2023-01-23T05:51:28.093Z\",\"_value\":114,\"_field\":\"value\",\"_measurement\":\"Puls\"},{\"result\":\"_result\",\"table\":1,\"_start\":\"2023-01-19T00:35:58.94679632Z\",\"_stop\":\"2023-01-26T00:35:58.94679632Z\",\"_time\":\"2023-01-23T06:07:26.392Z\",\"_value\":106,\"_field\":\"value\",\"_measurement\":\"Puls\"},{\"result\":\"_result\",\"table\":1,\"_start\":\"2023-01-19T00:35:58.94679632Z\",\"_stop\":\"2023-01-26T00:35:58.94679632Z\",\"_time\":\"2023-01-24T07:07:26.442Z\",\"_value\":106,\"_field\":\"value\",\"_measurement\":\"Puls\"},{\"result\":\"_result\",\"table\":1,\"_start\":\"2023-01-19T00:35:58.94679632Z\",\"_stop\":\"2023-01-26T00:35:58.94679632Z\",\"_time\":\"2023-01-24T07:22:26.521Z\",\"_value\":85,\"_field\":\"value\",\"_measurement\":\"Puls\"},{\"result\":\"_result\",\"table\":2,\"_start\":\"2023-01-19T00:35:58.94679632Z\",\"_stop\":\"2023-01-26T00:35:58.94679632Z\",\"_time\":\"2023-01-23T05:50:25.342Z\",\"_value\":127,\"_field\":\"value\",\"_measurement\":\"Systole\"},{\"result\":\"_result\",\"table\":2,\"_start\":\"2023-01-19T00:35:58.94679632Z\",\"_stop\":\"2023-01-26T00:35:58.94679632Z\",\"_time\":\"2023-01-23T06:07:26.39Z\",\"_value\":114,\"_field\":\"value\",\"_measurement\":\"Systole\"},{\"result\":\"_result\",\"table\":2,\"_start\":\"2023-01-19T00:35:58.94679632Z\",\"_stop\":\"2023-01-26T00:35:58.94679632Z\",\"_time\":\"2023-01-24T07:07:26.439Z\",\"_value\":114,\"_field\":\"value\",\"_measurement\":\"Systole\"},{\"result\":\"_result\",\"table\":2,\"_start\":\"2023-01-19T00:35:58.94679632Z\",\"_stop\":\"2023-01-26T00:35:58.94679632Z\",\"_time\":\"2023-01-24T07:22:26.521Z\",\"_value\":107,\"_field\":\"value\",\"_measurement\":\"Systole\"}]",
                                                 "payloadType": "json",
                                                 "x": 220,
                                                 "y": 280,
                                                 "wires": [
                                                     [
                                                         "efd1ab4c73f3d571",
                                                         "a9c39616decfa97c"
                                                     ]
                                                 ]
                                             },
                                             {
                                                 "id": "4d853addf9c082fb",
                                                 "type": "inject",
                                                 "z": "1983aa28392732ca",
                                                 "name": "",
                                                 "props": [
                                                     {
                                                         "p": "payload"
                                                     },
                                                     {
                                                         "p": "topic",
                                                         "vt": "str"
                                                     }
                                                 ],
                                                 "repeat": "",
                                                 "crontab": "",
                                                 "once": false,
                                                 "onceDelay": 0.1,
                                                 "topic": "Diastole",
                                                 "payload": "88",
                                                 "payloadType": "num",
                                                 "x": 500,
                                                 "y": 120,
                                                 "wires": [
                                                     [
                                                         "2d8acec0ec2da68e"
                                                     ]
                                                 ]
                                             },
                                             {
                                                 "id": "2d8acec0ec2da68e",
                                                 "type": "ui_chart",
                                                 "z": "1983aa28392732ca",
                                                 "name": "",
                                                 "group": "57f13d6f733e5c9d",
                                                 "order": 2,
                                                 "width": 0,
                                                 "height": 0,
                                                 "label": "Blutdruck und Puls",
                                                 "chartType": "line",
                                                 "legend": "true",
                                                 "xformat": "dd HH:mm",
                                                 "interpolate": "linear",
                                                 "nodata": "",
                                                 "dot": false,
                                                 "ymin": "",
                                                 "ymax": "",
                                                 "removeOlder": 1,
                                                 "removeOlderPoints": "50",
                                                 "removeOlderUnit": "604800",
                                                 "cutout": 0,
                                                 "useOneColor": false,
                                                 "useUTC": false,
                                                 "colors": [
                                                     "#1f77b4",
                                                     "#aec7e8",
                                                     "#ff7f0e",
                                                     "#2ca02c",
                                                     "#98df8a",
                                                     "#d62728",
                                                     "#ff9896",
                                                     "#9467bd",
                                                     "#c5b0d5"
                                                 ],
                                                 "outputs": 1,
                                                 "useDifferentColor": false,
                                                 "className": "",
                                                 "x": 770,
                                                 "y": 180,
                                                 "wires": [
                                                     []
                                                 ]
                                             },
                                             {
                                                 "id": "0ca3dc50cb11869a",
                                                 "type": "inject",
                                                 "z": "1983aa28392732ca",
                                                 "name": "",
                                                 "props": [
                                                     {
                                                         "p": "payload"
                                                     },
                                                     {
                                                         "p": "topic",
                                                         "vt": "str"
                                                     }
                                                 ],
                                                 "repeat": "",
                                                 "crontab": "",
                                                 "once": false,
                                                 "onceDelay": 0.1,
                                                 "topic": "Systole",
                                                 "payload": "170",
                                                 "payloadType": "num",
                                                 "x": 490,
                                                 "y": 160,
                                                 "wires": [
                                                     [
                                                         "2d8acec0ec2da68e"
                                                     ]
                                                 ]
                                             },
                                             {
                                                 "id": "efd1ab4c73f3d571",
                                                 "type": "change",
                                                 "z": "1983aa28392732ca",
                                                 "name": "Create Object Arrays",
                                                 "rules": [
                                                     {
                                                         "t": "set",
                                                         "p": "payload",
                                                         "pt": "msg",
                                                         "to": "[\t   {\t       \"series\" : [\"Systole\",\"Diastole\",\"Puls\"],\t       \"data\": [\t           [\t               payload[_measurement=\"Systole\"].{\t                   \"x\" : $toMillis(_time),\t                   \"y\" : _value\t    \t               }\t           ],\t           [\t               payload[_measurement=\"Diastole\"].{\t                   \"x\" : $toMillis(_time),\t                   \"y\" : _value\t    \t               }\t           ],\t           [\t               payload[_measurement=\"Puls\"].{\t                   \"x\" : $toMillis(_time),\t                   \"y\" : _value\t    \t               }\t           ]\t       ],\t       \"labels\" : [\"Systole\",\"Diastole\",\"Puls\"]\t    }\t]",
                                                         "tot": "jsonata"
                                                     }
                                                 ],
                                                 "action": "",
                                                 "property": "",
                                                 "from": "",
                                                 "to": "",
                                                 "reg": false,
                                                 "x": 500,
                                                 "y": 280,
                                                 "wires": [
                                                     [
                                                         "2d8acec0ec2da68e",
                                                         "cb3a1a566bc5679f"
                                                     ]
                                                 ]
                                             },
                                             {
                                                 "id": "097b4e4032b4bcff",
                                                 "type": "inject",
                                                 "z": "1983aa28392732ca",
                                                 "name": "",
                                                 "props": [
                                                     {
                                                         "p": "payload"
                                                     },
                                                     {
                                                         "p": "topic",
                                                         "vt": "str"
                                                     }
                                                 ],
                                                 "repeat": "",
                                                 "crontab": "",
                                                 "once": false,
                                                 "onceDelay": 0.1,
                                                 "topic": "Puls",
                                                 "payload": "75",
                                                 "payloadType": "num",
                                                 "x": 510,
                                                 "y": 200,
                                                 "wires": [
                                                     [
                                                         "2d8acec0ec2da68e"
                                                     ]
                                                 ]
                                             },
                                             {
                                                 "id": "5b8909ad22babab7",
                                                 "type": "inject",
                                                 "z": "1983aa28392732ca",
                                                 "name": "löschen",
                                                 "props": [
                                                     {
                                                         "p": "payload"
                                                     }
                                                 ],
                                                 "repeat": "",
                                                 "crontab": "",
                                                 "once": false,
                                                 "onceDelay": 0.1,
                                                 "topic": "",
                                                 "payload": "[]",
                                                 "payloadType": "json",
                                                 "x": 510,
                                                 "y": 60,
                                                 "wires": [
                                                     [
                                                         "2d8acec0ec2da68e"
                                                     ]
                                                 ]
                                             },
                                             {
                                                 "id": "a9c39616decfa97c",
                                                 "type": "debug",
                                                 "z": "1983aa28392732ca",
                                                 "name": "Array aus InfluxDB Abfrage",
                                                 "active": true,
                                                 "tosidebar": true,
                                                 "console": false,
                                                 "tostatus": false,
                                                 "complete": "payload",
                                                 "targetType": "msg",
                                                 "statusVal": "",
                                                 "statusType": "auto",
                                                 "x": 520,
                                                 "y": 320,
                                                 "wires": []
                                             },
                                             {
                                                 "id": "cb3a1a566bc5679f",
                                                 "type": "debug",
                                                 "z": "1983aa28392732ca",
                                                 "name": "Array zur Initialisierung der Chart Node",
                                                 "active": true,
                                                 "tosidebar": true,
                                                 "console": false,
                                                 "tostatus": false,
                                                 "complete": "payload",
                                                 "targetType": "msg",
                                                 "statusVal": "",
                                                 "statusType": "auto",
                                                 "x": 830,
                                                 "y": 280,
                                                 "wires": []
                                             },
                                             {
                                                 "id": "57f13d6f733e5c9d",
                                                 "type": "ui_group",
                                                 "name": "Test",
                                                 "tab": "20b3095113f94d70",
                                                 "order": 2,
                                                 "disp": true,
                                                 "width": "6",
                                                 "collapse": false,
                                                 "className": ""
                                             },
                                             {
                                                 "id": "20b3095113f94d70",
                                                 "type": "ui_tab",
                                                 "name": "Home",
                                                 "icon": "dashboard",
                                                 "order": 1,
                                                 "disabled": false,
                                                 "hidden": false
                                             }
                                          ]
                                          

                                          Du siehst wie man mit einer Change Node durch Filtern von Objekten und gleichzeitiger Neuerstellung - da ist JSONATA wirklich genial, völlig neue Objekte in der gewünschten Form erzeugen kann.

                                          Oben siehst Du ja das Array mit den Datensätzen aus der InfluxDB - das völlig neu erstellt wird, wie die Chart Node es braucht und wie es in der Beschreibung von Steve stand.

                                          Aus diesen Objekten:

                                          27143a53-7527-4859-a933-5d11e0b3beb8-image.png

                                          wurde diese alle je nach _measurement in verschiedene data Objekte gespeichert und gleichzeitig die Werte für die x und y-Achse generiert.

                                          6dab5899-8cea-41d3-acec-83c65df5fc89-image.png

                                          Im ersten Array = grün findest Du alle systolischen Werte mit dem timestamp als x und der entsprechenden Wert als y.

                                          Im zweiten Array = gelb findest Du alle diastolischen Werte mit dem timestamp als x und der entsprechenden Wert als y.

                                          Im dritten Array = hellblau findest Du alle Puls-Werte mit dem timestamp als x und der entsprechenden Wert als y.

                                          5bf271a7-ca66-41fc-befd-39ccd2d5519a-image.png

                                          Hier der Inhalt des Change / JSONATA Erstellung des Objektes:

                                          [
                                             {
                                                 "series" : ["Systole","Diastole","Puls"],
                                                 "data": [
                                                     [
                                                         payload[_measurement="Systole"].{
                                                             "x" : $toMillis(_time),
                                                             "y" : _value
                                              
                                                         }
                                                     ],
                                                     [
                                                         payload[_measurement="Diastole"].{
                                                             "x" : $toMillis(_time),
                                                             "y" : _value
                                              
                                                         }
                                                     ],
                                                     [
                                                         payload[_measurement="Puls"].{
                                                             "x" : $toMillis(_time),
                                                             "y" : _value
                                              
                                                         }
                                                     ]
                                                 ],
                                                 "labels" : ["Systole","Diastole","Puls"]
                                              }
                                          ]
                                          

                                          Also wie gesagt beschäftige Dich mit Arrays, Objekten, Filterung und Objekterstellung mit JSONATA.

                                          Wenn Du das mit Javascript programmieren wolltest, bräuchtest Du das Mehrfache an Code.

                                          Wie gesagt der Schlüssel ist der Screenshot, wie die Arrays und Objekte aufgebaut sein müssen, den ich aus dem Artikel von Steve kopiert hatte (https://forum.iobroker.net/post/934428).

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

                                            @mickym Hallo Micky,
                                            erstmal vielen Dank.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            383
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

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