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. Blockly
  5. JSON in Objekt/Datenpunkt umwandeln

NEWS

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

  • 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

JSON in Objekt/Datenpunkt umwandeln

Geplant Angeheftet Gesperrt Verschoben Blockly
72 Beiträge 17 Kommentatoren 18.5k Aufrufe 17 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 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
    schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
    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
      schrieb am zuletzt editiert von
      #19

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

      1 Antwort Letzte Antwort
      0
      • mickymM Offline
        mickymM Offline
        mickym
        Most Active
        schrieb am zuletzt editiert von
        #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 Antwort Letzte Antwort
        0
        • H Offline
          H Offline
          HotMaggi
          schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
          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 Nicht stören
            HomoranH Nicht stören
            Homoran
            Global Moderator Administrators
            schrieb am zuletzt editiert von 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 - es gibt fast nichts, was nicht auch für andere interessant ist.

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

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

            H 1 Antwort Letzte Antwort
            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
              schrieb am zuletzt editiert von
              #23

              @homoran

              Hallo Homoran,

              was meinst du mit Muster?

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

              mickymM CodierknechtC HomoranH 3 Antworten Letzte Antwort
              0
              • H HotMaggi

                @homoran

                Hallo Homoran,

                was meinst du mit Muster?

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

                mickymM Offline
                mickymM Offline
                mickym
                Most Active
                schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                1
                • H HotMaggi

                  @homoran

                  Hallo Homoran,

                  was meinst du mit Muster?

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

                  CodierknechtC Offline
                  CodierknechtC Offline
                  Codierknecht
                  Developer Most Active
                  schrieb am zuletzt editiert von
                  #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 Antworten Letzte Antwort
                  1
                  • H HotMaggi

                    @homoran

                    Hallo Homoran,

                    was meinst du mit Muster?

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

                    HomoranH Nicht stören
                    HomoranH Nicht stören
                    Homoran
                    Global Moderator Administrators
                    schrieb am zuletzt editiert von
                    #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 - es gibt fast nichts, was nicht auch für andere interessant ist.

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

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

                    H 1 Antwort Letzte Antwort
                    0
                    • CodierknechtC Codierknecht

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

                      Achtung: Stolperfalle Groß-/Kleinschreibung!

                      H Offline
                      H Offline
                      HotMaggi
                      schrieb am zuletzt editiert von
                      #27

                      @codierknecht

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

                      jetzt geht es

                      vielen lieben Dank !!!

                      1 Antwort Letzte Antwort
                      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
                        schrieb am zuletzt editiert von
                        #28

                        @homoran

                        passt nun, auch an dich danke "!!

                        M 1 Antwort Letzte Antwort
                        0
                        • H HotMaggi

                          @homoran

                          passt nun, auch an dich danke "!!

                          M Offline
                          M Offline
                          Matze1909
                          schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                          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
                            schrieb am zuletzt editiert von
                            #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 Antwort Letzte Antwort
                            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
                              schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                              1
                              • paul53P paul53

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

                                M Offline
                                M Offline
                                Matze1909
                                schrieb am zuletzt editiert von
                                #32

                                Ich habe es hinbekommen.
                                Zu erst das was unter energy steht in einen separaten Datenpunkt und dann mit der Liste arbeiten:
                                46f127e8-7798-412b-85c8-23d5623e7949-image.png

                                CodierknechtC 1 Antwort Letzte Antwort
                                0
                                • M Matze1909

                                  Ich habe es hinbekommen.
                                  Zu erst das was unter energy steht in einen separaten Datenpunkt und dann mit der Liste arbeiten:
                                  46f127e8-7798-412b-85c8-23d5623e7949-image.png

                                  CodierknechtC Offline
                                  CodierknechtC Offline
                                  Codierknecht
                                  Developer Most Active
                                  schrieb am zuletzt editiert von Codierknecht
                                  #33

                                  @matze1909
                                  Man könnte auch lediglich das JSON in einen DP schreiben und dann mit Aliasen die einzelnen Werte rauspflücken.

                                  "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

                                  M 1 Antwort Letzte Antwort
                                  1
                                  • CodierknechtC Codierknecht

                                    @matze1909
                                    Man könnte auch lediglich das JSON in einen DP schreiben und dann mit Aliasen die einzelnen Werte rauspflücken.

                                    M Offline
                                    M Offline
                                    Matze1909
                                    schrieb am zuletzt editiert von Matze1909
                                    #34

                                    @paul53 vielen Dank...deinen Beitrag hatte ich im ganzen "machen" inhaltlich völlig überlesen. So ist es ja noch viel einfacher.
                                    Danke und einen schönen Abend
                                    Matze

                                    CodierknechtC 1 Antwort Letzte Antwort
                                    0
                                    • M Matze1909

                                      @paul53 vielen Dank...deinen Beitrag hatte ich im ganzen "machen" inhaltlich völlig überlesen. So ist es ja noch viel einfacher.
                                      Danke und einen schönen Abend
                                      Matze

                                      CodierknechtC Offline
                                      CodierknechtC Offline
                                      Codierknecht
                                      Developer Most Active
                                      schrieb am zuletzt editiert von Codierknecht
                                      #35

                                      @matze1909 sagte in JSON in Objekt/Datenpunkt umwandeln:

                                      Danke...ich benötige die Daten aber als Datenpunkt. Wenn ich dich richtig verstanden habe, habe ich dann keine Datenpunkte, oder?

                                      Doch.
                                      Aliase werden im Objektbaum unterhalb von alias.0 angelegt.
                                      Der Alias „guckt“ auf den DP mit dem JSON.
                                      Über die Konvertierungsfunktion kann man dann einzelne Werte aus dem JSON holen.

                                      JSON.parse(val).battery.voltage
                                      

                                      "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

                                      1 Antwort Letzte Antwort
                                      0
                                      • M Offline
                                        M Offline
                                        Matze1909
                                        schrieb am zuletzt editiert von Matze1909
                                        #36

                                        Ich schaue mir das mit den Aliasen mal an.
                                        Aber noch eine Frage. In meinem Log steht:
                                        request blockly block is deprecated - please use "http get" instead

                                        Die request Funktion ist also veraltet und mal sollte stattdessen die http get Funktion nehmen. Aber wie kann ich dann hierüber einen Datenpunkt oder eine variable mit den JSON Daten aus der url füllen?
                                        Nutze ich die http get Funktion, bleibt bei mir die result Variable bzw. der Datenpunkt leer.

                                        Mein Script sieht jetzt so aus:
                                        2d37d486-97f6-433b-ab75-1b699982e9f4-image.png

                                        Was müsste ich verändern?

                                        paul53P 1 Antwort Letzte Antwort
                                        0
                                        • M Matze1909

                                          Ich schaue mir das mit den Aliasen mal an.
                                          Aber noch eine Frage. In meinem Log steht:
                                          request blockly block is deprecated - please use "http get" instead

                                          Die request Funktion ist also veraltet und mal sollte stattdessen die http get Funktion nehmen. Aber wie kann ich dann hierüber einen Datenpunkt oder eine variable mit den JSON Daten aus der url füllen?
                                          Nutze ich die http get Funktion, bleibt bei mir die result Variable bzw. der Datenpunkt leer.

                                          Mein Script sieht jetzt so aus:
                                          2d37d486-97f6-433b-ab75-1b699982e9f4-image.png

                                          Was müsste ich verändern?

                                          paul53P Offline
                                          paul53P Offline
                                          paul53
                                          schrieb am zuletzt editiert von paul53
                                          #37

                                          @matze1909 sagte: Was müsste ich verändern?

                                          Es gibt unter "Aktionen" die Variable data (anstelle von result).

                                          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

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


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          486

                                          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