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
    11
    1
    88

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    11
    1
    556

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.7k

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.
  • paul53P paul53

    @hans_m sagte: Spannung in einen eigenen Datenpunkt schreiben.

    Blockly_temp.JPG

    H Offline
    H Offline
    Hans_M
    schrieb am zuletzt editiert von
    #65

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

    CodierknechtC 1 Antwort Letzte Antwort
    0
    • 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 Offline
            HomoranH Offline
            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 Offline
              HomoranH Offline
              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

                        359

                        Online

                        32.5k

                        Benutzer

                        81.8k

                        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