Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. JSON in Objekt/Datenpunkt umwandeln

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    JSON in Objekt/Datenpunkt umwandeln

    This topic has been deleted. Only users with topic management privileges can see it.
    • paul53
      paul53 @micweg last edited by 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 1 Reply Last reply Reply Quote 0
      • M
        micweg @paul53 last edited by

        @paul53 wunderbar, vielen Dank. Hat geklappt. 🙂

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

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

          1 Reply Last reply Reply Quote 0
          • H
            HotMaggi last edited by 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
              }
            ]
            
            Homoran 1 Reply Last reply Reply Quote 0
            • Homoran
              Homoran Global Moderator Administrators @HotMaggi last edited by 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 1 Reply Last reply Reply Quote 0
              • H
                HotMaggi @Homoran last edited by

                @homoran

                Hallo Homoran,

                was meinst du mit Muster?

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

                mickym Codierknecht Homoran 3 Replies Last reply Reply Quote 0
                • mickym
                  mickym Most Active @HotMaggi last edited by mickym

                  @hotmaggi

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

                  Lt. Deinem JSON muss Value gross geschrieben werden.

                  1 Reply Last reply Reply Quote 1
                  • Codierknecht
                    Codierknecht Developer Most Active @HotMaggi last edited by

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

                    Achtung: Stolperfalle Groß-/Kleinschreibung!

                    H D 2 Replies Last reply Reply Quote 1
                    • Homoran
                      Homoran Global Moderator Administrators @HotMaggi last edited by

                      @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 1 Reply Last reply Reply Quote 0
                      • H
                        HotMaggi @Codierknecht last edited by

                        @codierknecht

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

                        jetzt geht es

                        vielen lieben Dank !!!

                        1 Reply Last reply Reply Quote 0
                        • H
                          HotMaggi @Homoran last edited by

                          @homoran

                          passt nun, auch an dich danke "!!

                          M 1 Reply Last reply Reply Quote 0
                          • M
                            Matze1909 @HotMaggi last edited by 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 1 Reply Last reply Reply Quote 0
                            • M
                              Matze1909 @Matze1909 last edited by

                              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?

                              paul53 1 Reply Last reply Reply Quote 0
                              • paul53
                                paul53 @Matze1909 last edited by 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 1 Reply Last reply Reply Quote 1
                                • M
                                  Matze1909 @paul53 last edited by

                                  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

                                  Codierknecht 1 Reply Last reply Reply Quote 0
                                  • Codierknecht
                                    Codierknecht Developer Most Active @Matze1909 last edited by Codierknecht

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

                                    M 1 Reply Last reply Reply Quote 1
                                    • M
                                      Matze1909 @Codierknecht last edited by 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

                                      Codierknecht 1 Reply Last reply Reply Quote 0
                                      • Codierknecht
                                        Codierknecht Developer Most Active @Matze1909 last edited by Codierknecht

                                        @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
                                        
                                        1 Reply Last reply Reply Quote 0
                                        • M
                                          Matze1909 last edited by 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?

                                          paul53 1 Reply Last reply Reply Quote 0
                                          • paul53
                                            paul53 @Matze1909 last edited by paul53

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

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

                                            Blockly_temp.JPG

                                            Thomas Schulze 1 Reply Last reply Reply Quote 1
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            944
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

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