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

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    14
    1
    222

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    1.8k

JSON in Objekt/Datenpunkt umwandeln

Geplant Angeheftet Gesperrt Verschoben Blockly
75 Beiträge 18 Kommentatoren 19.1k Aufrufe 18 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.
  • H Hans_M

    @paul53 funktioniert...manchmal ist es so einfach, vielen Dank!
    Aber was genau ist der Unterschied?

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

    @hans_m sagte in JSON in Objekt/Datenpunkt umwandeln:

    Aber was genau ist der Unterschied?

    1. @paul53 zeigt Dir, wie man mit dem Wert des triggernden Objektes arbeitet.
      Der Trigger kennt den Wert bereits. Den nochmal irgendwo her zu lesen ist suboptimal und verschwendet Ressourcen.
    2. Du prömpelst am Gesamtobjekt herum. Was Du aber brauchst, ist der "Wert" des Zustands vom Objekt.
      Also nicht obj.voltage, sondern obj.state.val.voltage. Das wird klarer, wenn man sich das JS hinter dem Blockly ansieht.
    on({ id: '0_userdata.0.test', change: 'ne' }, async (obj) => {
      spannung = getAttr(getObject('0_userdata.0.test'), 'voltage'); // Dein Konstrukt
      spannung = getAttr(obj.state.val, 'voltage'); // Paul's Lösung
    });
    
    

    "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 1 Antwort Letzte Antwort
    0
    • CodierknechtC Codierknecht

      @hans_m sagte in JSON in Objekt/Datenpunkt umwandeln:

      Aber was genau ist der Unterschied?

      1. @paul53 zeigt Dir, wie man mit dem Wert des triggernden Objektes arbeitet.
        Der Trigger kennt den Wert bereits. Den nochmal irgendwo her zu lesen ist suboptimal und verschwendet Ressourcen.
      2. Du prömpelst am Gesamtobjekt herum. Was Du aber brauchst, ist der "Wert" des Zustands vom Objekt.
        Also nicht obj.voltage, sondern obj.state.val.voltage. Das wird klarer, wenn man sich das JS hinter dem Blockly ansieht.
      on({ id: '0_userdata.0.test', change: 'ne' }, async (obj) => {
        spannung = getAttr(getObject('0_userdata.0.test'), 'voltage'); // Dein Konstrukt
        spannung = getAttr(obj.state.val, 'voltage'); // Paul's Lösung
      });
      
      
      H Offline
      H Offline
      Hans_M
      schrieb am zuletzt editiert von
      #67

      @codierknecht verstanden...vielen Dank

      5 1 Antwort Letzte Antwort
      0
      • H Hans_M

        @codierknecht verstanden...vielen Dank

        5 Offline
        5 Offline
        5tift
        schrieb am zuletzt editiert von
        #68

        Ich hätte da auch mal eine Frage.
        Ich habe im DP folgende Werte für die Spannungswerte der einzelnen Zellen meines BKW Akkus.

        {"cells":[3.397,3.397,3.399,3.398,3.401,3.4,3.401,3.391,3.394,3.392,3.394,3.395,3.396,3.396],"min":3.391,"max":3.401,"avg":3.3965}
        

        Wie bekomme ich diese in einzelne DP um sie zu visualisieren?

        Gruß 5tift

        HomoranH 1 Antwort Letzte Antwort
        0
        • 5 5tift

          Ich hätte da auch mal eine Frage.
          Ich habe im DP folgende Werte für die Spannungswerte der einzelnen Zellen meines BKW Akkus.

          {"cells":[3.397,3.397,3.399,3.398,3.401,3.4,3.401,3.391,3.394,3.392,3.394,3.395,3.396,3.396],"min":3.391,"max":3.401,"avg":3.3965}
          

          Wie bekomme ich diese in einzelne DP um sie zu visualisieren?

          Gruß 5tift

          HomoranH Nicht stören
          HomoranH Nicht stören
          Homoran
          Global Moderator Administrators
          schrieb am zuletzt editiert von
          #69

          @5tift mal als Anregung
          Screenshot_20250507-151211_Firefox.jpg

          statt debug in entsprechende Datenpunkte schreiben

          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 -

          1 Antwort Letzte Antwort
          0
          • HomoranH Nicht stören
            HomoranH Nicht stören
            Homoran
            Global Moderator Administrators
            schrieb am zuletzt editiert von
            #70

            Screenshot_20250507-152201_Firefox.jpg

            Datenpunkte selber anlegen und Variable entsprechend ändern

            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 -

            5 1 Antwort Letzte Antwort
            0
            • CodierknechtC Offline
              CodierknechtC Offline
              Codierknecht
              Developer Most Active
              schrieb am zuletzt editiert von
              #71

              @5tift sagte in JSON in Objekt/Datenpunkt umwandeln:

              Wie bekomme ich diese in einzelne DP um sie zu visualisieren?

              Entweder per Script, so wie @Homoran es zeigt, oder Du legst Dir für jede Zelle einen Alias an. Dann geht das auch ohne Script.
              https://forum.iobroker.net/topic/70481/blockly-for-dummies-starthilfe-und-tipps/12

              Die Konvertierungen würden so aussehen:

              JSON.parse(val).cells[0]
              JSON.parse(val).cells[1]
              JSON.parse(val).cells[2]
              ...
              

              e020c0a4-d468-4450-91ec-cd96f9f15b03-image.png

              "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
              • HomoranH Homoran

                Screenshot_20250507-152201_Firefox.jpg

                Datenpunkte selber anlegen und Variable entsprechend ändern

                5 Offline
                5 Offline
                5tift
                schrieb am zuletzt editiert von
                #72

                @homoran
                Vielen Dank für den schnellen Input, werd mal versuchen das nachzubauen :blush:

                1 Antwort Letzte Antwort
                0
                • CyberraphC Online
                  CyberraphC Online
                  Cyberraph
                  schrieb am zuletzt editiert von
                  #73
                  Hallo zusammen!

                  Es tut mir wirklich Leid, dass ich das hier nochmal ausgrabe. Trotz längerer Suche und grübeln, fällt mir mein Fehler nicht auf, wo es hakt.

                  Ich lege mir aktuell meine ALIAS etwas besser an.

                  Dabei habe ich auch mehrere Temperatursensoren an einem ESP WLAN Chip hängen, die ich per MQTT als JSON String reinbekomme (korrigiert meine Teminologie, falls falsch bezeichnet).

                  Zuvor hatte ich mir ein Blockly angelegt, das mir die Werte ein DPs in meinem User-Bereich reingespielt hat.
                  Welche ich dann den Alias-DPs zugewiesen habe.

                  Aber da ich es gesehen, habe, dass es per Alias-Konvertierfunktion deutlich "schlanker" ginge, wollte ich es nun damit lösen,
                  aber bekomme es nicht hin speziell bei angeführtem MQTT-Datenpunkt.

                  Wie bekomme ich z.B. von "DS18B20-1" den Wert von "Temperature" in meinen Alias-DP mit Typ Zahl und Rolle value.temperature?

                  Der MQTT-Datenpunkt sieht folgendermaßen aus:
                  Objekt

                  {
                    "_id": "mqtt.0.Smarthome-Raphael.01-Keller.03-Heizraum.Anlegefuehler-DS18B20.tele.SENSOR",
                    "common": {
                      "name": "Smarthome-Raphael/01-Keller/03-Heizraum/Anlegefuehler-DS18B20/tele/SENSOR",
                      "write": true,
                      "read": true,
                      "role": "variable",
                      "desc": "mqtt client variable",
                      "type": "mixed"
                    },
                    "native": {
                      "topic": "Smarthome-Raphael/01-Keller/03-Heizraum/Anlegefuehler-DS18B20/tele/SENSOR"
                    },
                    "type": "state",
                    "acl": {
                      "object": 1636,
                      "state": 1636,
                      "owner": "system.user.admin",
                      "ownerGroup": "system.group.administrator"
                    },
                    "from": "system.adapter.mqtt.0",
                    "user": "system.user.admin",
                    "ts": 1737926957962
                  }
                  


                  Inhalt des Objekts

                  {"Time":"2025-12-28T15:31:46","DS18B20-1":{"Id":"189F211864FF","Temperature":53.0},"DS18B20-2":{"Id":"369F211864FF","Temperature":49.6},"DS18B20-3":{"Id":"9998211864FF","Temperature":13.7},"DS18B20-4":{"Id":"9D9C7D0A6461","Temperature":12.2},"DS18B20-5":{"Id":"AD99211864FF","Temperature":12.4},"DS18B20-6":{"Id":"C29F211864FF","Temperature":12.8},"TempUnit":"C"}
                  

                  Der Alias-Datenpunkt sieht folgendermaßen aus:
                  Objekt

                  {
                    "_id": "alias.0.9-Test.JSON-Auswertung",
                    "type": "state",
                    "common": {
                      "name": "JSON-Auswertung",
                      "type": "mixed",
                      "alias": {
                        "id": "mqtt.0.Smarthome-Raphael.01-Keller.03-Heizraum.Anlegefuehler-DS18B20.tele.SENSOR",
                        "read": "JSON.parse(val).DS18B20-1.Temperature"
                      },
                      "desc": "Manuell erzeugt",
                      "unit": "°C",
                      "read": true,
                      "write": true
                    },
                    "native": {},
                    "acl": {
                      "object": 1636,
                      "state": 1636,
                      "owner": "system.user.admin",
                      "ownerGroup": "system.group.administrator"
                    },
                    "from": "system.adapter.admin.0",
                    "user": "system.user.admin",
                    "ts": 1766932962166
                  }
                  

                  Inhalt des Objekts

                  null
                  

                  Meine Versuch der Alias-Konvertierung beim Lesen:

                  Ich schreibe rein -> JSON.parse(val).DS18B20-1.Temperature

                  Anmerkung:
                  Interessant ist er schreibt bei Zustand "State does not exist" // Wenn ich aber Temperature weg lasse, wertet er es offensichtlich aus, aber mit "null".


                  Bild_1.png


                  Bild_2.png

                  DANKE VIELMALS schon vorab für den Denkanstoß.

                  Beste Grüße!

                  io-Broker Neuling 2024 :-)

                  Bislang jedoch einiges an Beiträgen und Grundlagen eingeflößt, um etwas besser empor zu irren.

                  paul53P 1 Antwort Letzte Antwort
                  0
                  • CyberraphC Cyberraph
                    Hallo zusammen!

                    Es tut mir wirklich Leid, dass ich das hier nochmal ausgrabe. Trotz längerer Suche und grübeln, fällt mir mein Fehler nicht auf, wo es hakt.

                    Ich lege mir aktuell meine ALIAS etwas besser an.

                    Dabei habe ich auch mehrere Temperatursensoren an einem ESP WLAN Chip hängen, die ich per MQTT als JSON String reinbekomme (korrigiert meine Teminologie, falls falsch bezeichnet).

                    Zuvor hatte ich mir ein Blockly angelegt, das mir die Werte ein DPs in meinem User-Bereich reingespielt hat.
                    Welche ich dann den Alias-DPs zugewiesen habe.

                    Aber da ich es gesehen, habe, dass es per Alias-Konvertierfunktion deutlich "schlanker" ginge, wollte ich es nun damit lösen,
                    aber bekomme es nicht hin speziell bei angeführtem MQTT-Datenpunkt.

                    Wie bekomme ich z.B. von "DS18B20-1" den Wert von "Temperature" in meinen Alias-DP mit Typ Zahl und Rolle value.temperature?

                    Der MQTT-Datenpunkt sieht folgendermaßen aus:
                    Objekt

                    {
                      "_id": "mqtt.0.Smarthome-Raphael.01-Keller.03-Heizraum.Anlegefuehler-DS18B20.tele.SENSOR",
                      "common": {
                        "name": "Smarthome-Raphael/01-Keller/03-Heizraum/Anlegefuehler-DS18B20/tele/SENSOR",
                        "write": true,
                        "read": true,
                        "role": "variable",
                        "desc": "mqtt client variable",
                        "type": "mixed"
                      },
                      "native": {
                        "topic": "Smarthome-Raphael/01-Keller/03-Heizraum/Anlegefuehler-DS18B20/tele/SENSOR"
                      },
                      "type": "state",
                      "acl": {
                        "object": 1636,
                        "state": 1636,
                        "owner": "system.user.admin",
                        "ownerGroup": "system.group.administrator"
                      },
                      "from": "system.adapter.mqtt.0",
                      "user": "system.user.admin",
                      "ts": 1737926957962
                    }
                    


                    Inhalt des Objekts

                    {"Time":"2025-12-28T15:31:46","DS18B20-1":{"Id":"189F211864FF","Temperature":53.0},"DS18B20-2":{"Id":"369F211864FF","Temperature":49.6},"DS18B20-3":{"Id":"9998211864FF","Temperature":13.7},"DS18B20-4":{"Id":"9D9C7D0A6461","Temperature":12.2},"DS18B20-5":{"Id":"AD99211864FF","Temperature":12.4},"DS18B20-6":{"Id":"C29F211864FF","Temperature":12.8},"TempUnit":"C"}
                    

                    Der Alias-Datenpunkt sieht folgendermaßen aus:
                    Objekt

                    {
                      "_id": "alias.0.9-Test.JSON-Auswertung",
                      "type": "state",
                      "common": {
                        "name": "JSON-Auswertung",
                        "type": "mixed",
                        "alias": {
                          "id": "mqtt.0.Smarthome-Raphael.01-Keller.03-Heizraum.Anlegefuehler-DS18B20.tele.SENSOR",
                          "read": "JSON.parse(val).DS18B20-1.Temperature"
                        },
                        "desc": "Manuell erzeugt",
                        "unit": "°C",
                        "read": true,
                        "write": true
                      },
                      "native": {},
                      "acl": {
                        "object": 1636,
                        "state": 1636,
                        "owner": "system.user.admin",
                        "ownerGroup": "system.group.administrator"
                      },
                      "from": "system.adapter.admin.0",
                      "user": "system.user.admin",
                      "ts": 1766932962166
                    }
                    

                    Inhalt des Objekts

                    null
                    

                    Meine Versuch der Alias-Konvertierung beim Lesen:

                    Ich schreibe rein -> JSON.parse(val).DS18B20-1.Temperature

                    Anmerkung:
                    Interessant ist er schreibt bei Zustand "State does not exist" // Wenn ich aber Temperature weg lasse, wertet er es offensichtlich aus, aber mit "null".


                    Bild_1.png


                    Bild_2.png

                    DANKE VIELMALS schon vorab für den Denkanstoß.

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

                    @Cyberraph sagte: JSON.parse(val).DS18B20-1.Temperature

                    Da "DS18B20-1" ein unzulässiges Zeichen (Minus) enthält, funktioniert es so nicht, sondern so:

                    JSON.parse(val)['DS18B20-1'].Temperature
                    

                    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

                    CyberraphC 1 Antwort Letzte Antwort
                    1
                    • paul53P paul53

                      @Cyberraph sagte: JSON.parse(val).DS18B20-1.Temperature

                      Da "DS18B20-1" ein unzulässiges Zeichen (Minus) enthält, funktioniert es so nicht, sondern so:

                      JSON.parse(val)['DS18B20-1'].Temperature
                      
                      CyberraphC Online
                      CyberraphC Online
                      Cyberraph
                      schrieb am zuletzt editiert von
                      #75

                      @paul53
                      Unglaublich, vielen Dank, das war es. Es zeigt im Dialog (zumindest über den Devices-Adapter) das Ergebnis vorab an.

                      Ich hatte schon eine Vermutung, dass man den Bindestrich irgendwo "escapen" muss.
                      Hab auch schon gesehen, dass es unterschiedliche Schreibweisen gibt,
                      aber es mit einem längeren inkl. verschachteltem JSON nicht verstanden.
                      -> JSON.parse(val)['value']
                      -> JSON.parse(val).value

                      Gesucht hätte ich zwar auch einschlägige Websites wie
                      https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse

                      aber dort ist es für mich als Laien, der gar keinen Programmierhintergrund hat, meist nicht komplett verständlich
                      wie es z.B. hier im iobroker bei der Konvertierfunktion richtig geschrieben gehört,
                      da es auf jenen Websites wohl "voll ausgeschrieben" steht
                      und der iobroker diverse Dinge automatisch umwandelt und es somit nicht ganz ausgeschrieben gehört (so laienhaft interpretiert von mir).

                      VIELEN VIELEN DANK, mein Problem ist jedenfalls gelöst. :-)


                      Bild_3.png

                      Beste Grüße!

                      io-Broker Neuling 2024 :-)

                      Bislang jedoch einiges an Beiträgen und Grundlagen eingeflößt, um etwas besser empor zu irren.

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


                      Support us

                      ioBroker
                      Community Adapters
                      Donate

                      542

                      Online

                      32.5k

                      Benutzer

                      81.9k

                      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