Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Blockly
  5. JSON in Objekt/Datenpunkt umwandeln

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    12
    1
    134

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    4.3k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.3k

JSON in Objekt/Datenpunkt umwandeln

Scheduled Pinned Locked Moved Blockly
75 Posts 18 Posters 20.2k Views 18 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • W warlord

    @paul53
    Guten Morgen...
    du hattest mir vor ein paar Wochen dieses Blockly erstellt
    2021-11-27_17h31_12.png
    Funktioniert bestens.
    Jetzt habe ich mir einen testserver mit dem zigbee adapter statt zigbee2mqtt installiert weil da die Werte schon einzeln und nicht in einem json dargestellt werden und du in meinem anderen Post sagtest das ich nicht in "userdata" einen Dp erstellen muß,sondern nur in mqtt0

    2021-12-08_10h34_51.png
    Nun dachte ich ,änderst das Blockly für diesen mqtt Datenpunkt
    2021-12-08_11h00_13.png
    in
    2021-12-08_10h47_23.png
    Tut leider nicht .... mit diesen warnings

    2021-12-08_11h03_05.png

    Ich hab aber schon bei beiden "type" auf Zahl gesetzt

    2021-12-08_11h06_46.png

    2021-12-08_11h08_49.png

    Jetzt weiß ich wieder nicht weiter...:anguished:

    paul53P Offline
    paul53P Offline
    paul53
    wrote on last edited by
    #12

    @warlord
    Wenn der Zigbee-Datenpunkt schon eine Zahl enthält, genügt der Block "binde object Zigbee-DP mit MQTT-DP".

    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

    W 1 Reply Last reply
    0
    • paul53P paul53

      @warlord
      Wenn der Zigbee-Datenpunkt schon eine Zahl enthält, genügt der Block "binde object Zigbee-DP mit MQTT-DP".

      W Offline
      W Offline
      warlord
      wrote on last edited by
      #13

      @paul53
      Funktioniert...
      Danke für die schnelle Hilfe...

      1 Reply Last reply
      0
      • H Offline
        H Offline
        hansmeier
        wrote on last edited by
        #14

        Moin !
        Ich bin auf diesen Beitrag durch die Suchfunktion aufmerksam geworden und benötige eure Hilfe.

        Ich möchte auch ein Json Objekt, daß ein WemosD1 (Tasmota) von meinem Stromzähler per MQTT schickt, auswerten und somit einzelne Datenpunkte zu bekommen.

        Der Datenpunkt mit dem Json Objekt sieht so aus:

        {"Time":"2022-12-31T11:49:53","SML":{"Total_Summe":148.15,"Power_curr":511.00}}
        

        Daraus möchte ich die beiden Werte Total_Summe und Power_curr extrahieren und zwei Datenpunkten zuweisen.
        Diese Datenpunkte habe ich in folgender Art erstellt :

        {
          "common": {
            "name": "AktuellerVerbrauch",
            "desc": "Manuell erzeugt",
            "role": "state",
            "type": "number",
            "read": true,
            "write": true,
            "def": 0,
            "unit": "W"
          },
          "type": "state",
          "native": {},
          "_id": "Armins.0.Strommesser.AktuellerVerbrauch",
          "acl": {
            "object": 1636,
            "state": 1636,
            "owner": "system.user.admin",
            "ownerGroup": "system.group.administrator"
          },
          "from": "system.adapter.admin.0",
          "user": "system.user.admin",
          "ts": 1672423442533
        }
        

        Mein Blockly dazu sieht so aus:
        Bildschirm­foto 2022-12-31 um 12.00.47.png

        Die Objekt ID ist der Datenpunkt mit dem Json Objekt
        hinter "aktualisiere" stehen die beiden manuell erstellten Datenpunkte.

        Leider funktioniert irgend etwas nicht. Die Datenpunkte werden nicht befüllt. Sie haben nach wie vor diesen Wert:

        {"ack":true} W
        

        Erkennt jemand meinen Fehler ? was mache ich falsch ? Oder gibt es einen anderen Weg, um an die beiden Daten aus dem Json Objekt heranzukommen ?

        Viele Dank schon mal für die Hilfe.

        1 Reply Last reply
        0
        • L Online
          L Online
          Lucky_ESA
          Developer Most Active
          wrote on last edited by
          #15

          @hansmeier Versuche es mal so.

          SML.Total_Summe
          SML.Power_curr

          Gruß//Lucky

          H M 2 Replies Last reply
          0
          • L Lucky_ESA

            @hansmeier Versuche es mal so.

            SML.Total_Summe
            SML.Power_curr

            Gruß//Lucky

            H Offline
            H Offline
            hansmeier
            wrote on last edited by
            #16

            @lucky_esa Bingo ! Das wars. Danke für den Tip.
            Schönen Gruß

            1 Reply Last reply
            0
            • L Lucky_ESA

              @hansmeier Versuche es mal so.

              SML.Total_Summe
              SML.Power_curr

              Gruß//Lucky

              M Offline
              M Offline
              micweg
              wrote on last edited by micweg
              #17

              Hallo,

              ich habe eine gleichartige Problemstellung. Dank eurer Infos hier, habe ich schon einen Teil lösen können. :)

              Ich lese meinen Stromzähler aus und bekomme die Daten über MQTT: Bildschirmfoto 2023-07-08 um 14.03.00.png

              Jede Sekunde kommt der Wert "power". In einem deutlich größeren Intervall (ca. 5 Min) wird auch der Zählerstand (energy_sum) und die Einspeisung (energy_supply) übermittelt. (Falls jemand fragt: ich weiß auch nicht, warum das so ist :) )

              Wie einer der Vorredner habe ich ein blockly erstellt:Bildschirmfoto 2023-07-08 um 17.18.36.png

              "power" funktioniert! :) Datenpunkt wird gefüllt, ich kann ihn in influxDB speichern und Grafana visualisieren.

              "energy_sum" und "energy_supply" funktionieren leider nicht. Auch wenn die Werte bereits mehrfach über MQTT übertragen wurden. Alle Datenpunkte sind angelegt. Für Zählerstand und Einspeisung steht aber immer nur "ack":true als Wert drin.

              Hat jemand einen Tipp für mich, wo ich hier falsch liege? Danke im Voraus.

              paul53P 1 Reply Last reply
              0
              • M micweg

                Hallo,

                ich habe eine gleichartige Problemstellung. Dank eurer Infos hier, habe ich schon einen Teil lösen können. :)

                Ich lese meinen Stromzähler aus und bekomme die Daten über MQTT: Bildschirmfoto 2023-07-08 um 14.03.00.png

                Jede Sekunde kommt der Wert "power". In einem deutlich größeren Intervall (ca. 5 Min) wird auch der Zählerstand (energy_sum) und die Einspeisung (energy_supply) übermittelt. (Falls jemand fragt: ich weiß auch nicht, warum das so ist :) )

                Wie einer der Vorredner habe ich ein blockly erstellt:Bildschirmfoto 2023-07-08 um 17.18.36.png

                "power" funktioniert! :) Datenpunkt wird gefüllt, ich kann ihn in influxDB speichern und Grafana visualisieren.

                "energy_sum" und "energy_supply" funktionieren leider nicht. Auch wenn die Werte bereits mehrfach über MQTT übertragen wurden. Alle Datenpunkte sind angelegt. Für Zählerstand und Einspeisung steht aber immer nur "ack":true als Wert drin.

                Hat jemand einen Tipp für mich, wo ich hier falsch liege? Danke im Voraus.

                paul53P Offline
                paul53P Offline
                paul53
                wrote on last edited by paul53
                #18

                @micweg sagte: Tipp für mich

                Wenn mit den Energiewerten auch immer "meter_number" mitkommt, dann versuche es mal so:

                Blockly_temp.JPG

                Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                M 1 Reply Last reply
                0
                • paul53P paul53

                  @micweg sagte: Tipp für mich

                  Wenn mit den Energiewerten auch immer "meter_number" mitkommt, dann versuche es mal so:

                  Blockly_temp.JPG

                  M Offline
                  M Offline
                  micweg
                  wrote on last edited by
                  #19

                  @paul53 wunderbar, vielen Dank. Hat geklappt. :)

                  1 Reply Last reply
                  0
                  • mickymM Online
                    mickymM Online
                    mickym
                    Most Active
                    wrote on last edited by
                    #20

                    https://forum.iobroker.net/topic/43856/json-oder-javascript-objekt-in-iobroker-datenpunkte-zerlegen

                    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 Reply Last reply
                    0
                    • H Offline
                      H Offline
                      HotMaggi
                      wrote on last edited by HotMaggi
                      #21

                      Hallo,
                      Ich bin hier neu und absoluter Anfänger in IOBroker, und auch in blockly... Bin im Moment am testen, was alles in IOBroker möglich ist.
                      Nun habe ich ein Problem, welches ich trotz suchen und lesen akt. nicht lösen kann.

                      Ich habe einen MQTT Client in IOBroker aufgesetzt und möchte von einem anderen System (mqtt-Broker) einen Stromwert auslesen. Verbindung klappt.
                      Im IOBroker Client, wie auch im MQTT-Explorer kommen im payload aber am Anfang und Ende eckige Klammern vor, diese verhindern wohl, dass ich mit blockly korrekt nach oben aufgeführtem Muster den Wert auslesen kann. Wenn ich die eckigen Klammern in mqtt-payload entferne, funktioniert mein Script 100 %. Auf der Serverseite gibt es keine Möglichkeit die Klammern zu entfernen...

                      Nun weiß ich nicht wie ich diese Klammern aus dem payload entfernen kann?
                      so sieht der payload aus.

                      Wäre toll wenn mir jemand einen Tipp geben lönnte.

                      [
                        {
                          "ID": 29092,
                          "Name": "StrominWatt",
                          "ObjectIdent": "",
                          "VariableTyp": 2,
                          "VariableAction": 0,
                          "VariableCustomAction": 1,
                          "VariableProfile": "",
                          "VariableCustomProfile": "~Watt",
                          "Value": 111
                        }
                      ]
                      
                      HomoranH 1 Reply Last reply
                      0
                      • H HotMaggi

                        Hallo,
                        Ich bin hier neu und absoluter Anfänger in IOBroker, und auch in blockly... Bin im Moment am testen, was alles in IOBroker möglich ist.
                        Nun habe ich ein Problem, welches ich trotz suchen und lesen akt. nicht lösen kann.

                        Ich habe einen MQTT Client in IOBroker aufgesetzt und möchte von einem anderen System (mqtt-Broker) einen Stromwert auslesen. Verbindung klappt.
                        Im IOBroker Client, wie auch im MQTT-Explorer kommen im payload aber am Anfang und Ende eckige Klammern vor, diese verhindern wohl, dass ich mit blockly korrekt nach oben aufgeführtem Muster den Wert auslesen kann. Wenn ich die eckigen Klammern in mqtt-payload entferne, funktioniert mein Script 100 %. Auf der Serverseite gibt es keine Möglichkeit die Klammern zu entfernen...

                        Nun weiß ich nicht wie ich diese Klammern aus dem payload entfernen kann?
                        so sieht der payload aus.

                        Wäre toll wenn mir jemand einen Tipp geben lönnte.

                        [
                          {
                            "ID": 29092,
                            "Name": "StrominWatt",
                            "ObjectIdent": "",
                            "VariableTyp": 2,
                            "VariableAction": 0,
                            "VariableCustomAction": 1,
                            "VariableProfile": "",
                            "VariableCustomProfile": "~Watt",
                            "Value": 111
                          }
                        ]
                        
                        HomoranH Do not disturb
                        HomoranH Do not disturb
                        Homoran
                        Global Moderator Administrators
                        wrote on last edited by Homoran
                        #22

                        @hotmaggi sagte in JSON in Objekt/Datenpunkt umwandeln:

                        diese verhindern wohl, dass ich mit blockly korrekt nach oben aufgeführtem Muster den Wert auslesen kann.

                        welches Muster?

                        Attribut 0.value von json

                        Screenshot_20230929-083251_Firefox.jpg

                        kein Support per PN! - Fragen im Forum stellen -

                        Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                        ioBroker freut sich auch über eine Spende für das Forum. Benutzt dazu den Spendenbutton im Header. Danke!

                        der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                        H 1 Reply Last reply
                        0
                        • HomoranH Homoran

                          @hotmaggi sagte in JSON in Objekt/Datenpunkt umwandeln:

                          diese verhindern wohl, dass ich mit blockly korrekt nach oben aufgeführtem Muster den Wert auslesen kann.

                          welches Muster?

                          Attribut 0.value von json

                          Screenshot_20230929-083251_Firefox.jpg

                          H Offline
                          H Offline
                          HotMaggi
                          wrote on last edited by
                          #23

                          @homoran

                          Hallo Homoran,

                          was meinst du mit Muster?

                          Soll ich das als Wert eingeben in blockly 0.value?

                          mickymM CodierknechtC HomoranH 3 Replies Last reply
                          0
                          • H HotMaggi

                            @homoran

                            Hallo Homoran,

                            was meinst du mit Muster?

                            Soll ich das als Wert eingeben in blockly 0.value?

                            mickymM Online
                            mickymM Online
                            mickym
                            Most Active
                            wrote on last edited by mickym
                            #24

                            @hotmaggi

                            b12586ed-6636-4f98-ab76-08874d9af809-image.png

                            Lt. Deinem JSON muss Value gross geschrieben werden.

                            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 Reply Last reply
                            1
                            • H HotMaggi

                              @homoran

                              Hallo Homoran,

                              was meinst du mit Muster?

                              Soll ich das als Wert eingeben in blockly 0.value?

                              CodierknechtC Online
                              CodierknechtC Online
                              Codierknecht
                              Developer Most Active
                              wrote on last edited by
                              #25

                              @hotmaggi
                              9779da24-2ff0-46a1-9f3b-adb249d9a7c6-image.png

                              Achtung: Stolperfalle Groß-/Kleinschreibung!

                              "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                              Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                              HmIP|ZigBee|Tasmota|Unifi
                              Zabbix Certified Specialist
                              Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                              H D 2 Replies Last reply
                              1
                              • H HotMaggi

                                @homoran

                                Hallo Homoran,

                                was meinst du mit Muster?

                                Soll ich das als Wert eingeben in blockly 0.value?

                                HomoranH Do not disturb
                                HomoranH Do not disturb
                                Homoran
                                Global Moderator Administrators
                                wrote on last edited by
                                #26

                                @hotmaggi sagte in JSON in Objekt/Datenpunkt umwandeln:

                                was meinst du mit Muster?

                                jetzt wirds weird!
                                Das war doch deine Formulierung und ich fragte beteits danach, was du meintest

                                kein Support per PN! - Fragen im Forum stellen -

                                Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                ioBroker freut sich auch über eine Spende für das Forum. Benutzt dazu den Spendenbutton im Header. Danke!

                                der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                                H 1 Reply Last reply
                                0
                                • CodierknechtC Codierknecht

                                  @hotmaggi
                                  9779da24-2ff0-46a1-9f3b-adb249d9a7c6-image.png

                                  Achtung: Stolperfalle Groß-/Kleinschreibung!

                                  H Offline
                                  H Offline
                                  HotMaggi
                                  wrote on last edited by
                                  #27

                                  @codierknecht

                                  oh wie banal... das war der Fehler mit der Großschreibung.

                                  jetzt geht es

                                  vielen lieben Dank !!!

                                  1 Reply Last reply
                                  0
                                  • HomoranH Homoran

                                    @hotmaggi sagte in JSON in Objekt/Datenpunkt umwandeln:

                                    was meinst du mit Muster?

                                    jetzt wirds weird!
                                    Das war doch deine Formulierung und ich fragte beteits danach, was du meintest

                                    H Offline
                                    H Offline
                                    HotMaggi
                                    wrote on last edited by
                                    #28

                                    @homoran

                                    passt nun, auch an dich danke "!!

                                    M 1 Reply Last reply
                                    0
                                    • H HotMaggi

                                      @homoran

                                      passt nun, auch an dich danke "!!

                                      M Offline
                                      M Offline
                                      Matze1909
                                      wrote on last edited by Matze1909
                                      #29

                                      Guten Abend,
                                      ich lese über eine URL das JSON aus und schreibe es in einen Datenpunkt (Daten). Nun will ich den Wert "level" in einen weiteren Datenpunkt schreiben. Das funktioniert aber leider nicht.
                                      Was kurios ist... den Wert "voltage" beispielsweise wird in einen Datenpunkt geschrieben. Was mache ich falsch?

                                      Hier mein Blockly:
                                      c7a6383b-eafd-4863-bd9c-0e90afae9041-image.png

                                      Hier ein Teil des Inhaltes vom Datenpunkt:
                                      9c621df1-09a4-4534-bdb9-2c6267f46e45-image.png

                                      Hier das Resultat in den Datenpunkten:
                                      bdfb0156-2c2f-4420-b1de-424c14954b19-image.png

                                      Der Datenpunkt "Akku" ist richtig.
                                      Der Datenpunkt "Akku_Stand" nicht.

                                      Ich habe keine Ahnung woran das liegt. Habt Ihr eine Idee?

                                      Viele Grüße
                                      Matze

                                      M 1 Reply Last reply
                                      0
                                      • M Matze1909

                                        Guten Abend,
                                        ich lese über eine URL das JSON aus und schreibe es in einen Datenpunkt (Daten). Nun will ich den Wert "level" in einen weiteren Datenpunkt schreiben. Das funktioniert aber leider nicht.
                                        Was kurios ist... den Wert "voltage" beispielsweise wird in einen Datenpunkt geschrieben. Was mache ich falsch?

                                        Hier mein Blockly:
                                        c7a6383b-eafd-4863-bd9c-0e90afae9041-image.png

                                        Hier ein Teil des Inhaltes vom Datenpunkt:
                                        9c621df1-09a4-4534-bdb9-2c6267f46e45-image.png

                                        Hier das Resultat in den Datenpunkten:
                                        bdfb0156-2c2f-4420-b1de-424c14954b19-image.png

                                        Der Datenpunkt "Akku" ist richtig.
                                        Der Datenpunkt "Akku_Stand" nicht.

                                        Ich habe keine Ahnung woran das liegt. Habt Ihr eine Idee?

                                        Viele Grüße
                                        Matze

                                        M Offline
                                        M Offline
                                        Matze1909
                                        wrote on last edited by
                                        #30

                                        Was mir eben aufgefallen ist:
                                        Battery enthält zwei werte in geschweiften Klammern.
                                        Energy enthält einen Wert in eckigen klammern, der wiederum 8 einzelne Werte in geschweiften Klammern enthält. Deswegen klappt das mit der gleichen Schreibweise nicht, wie bei Voltage.
                                        Mit welcher Schreibweise komme ich an den Wert unter level?

                                        paul53P 1 Reply Last reply
                                        0
                                        • M Matze1909

                                          Was mir eben aufgefallen ist:
                                          Battery enthält zwei werte in geschweiften Klammern.
                                          Energy enthält einen Wert in eckigen klammern, der wiederum 8 einzelne Werte in geschweiften Klammern enthält. Deswegen klappt das mit der gleichen Schreibweise nicht, wie bei Voltage.
                                          Mit welcher Schreibweise komme ich an den Wert unter level?

                                          paul53P Offline
                                          paul53P Offline
                                          paul53
                                          wrote on last edited by paul53
                                          #31

                                          @matze1909 sagt: Mit welcher Schreibweise komme ich an den Wert unter level?

                                          energy.0.level, denn energy enthält ein Array.
                                          Man kann einen Datenpunkt nach dem Schreiben nicht gleich wieder auslesen (asynchrone Ausführung). Nimm deshalb die Variable result.

                                          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                          M 1 Reply Last reply
                                          1
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          553

                                          Online

                                          32.7k

                                          Users

                                          82.4k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe