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.
    • 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
            • Thomas Schulze
              Thomas Schulze @paul53 last edited by

              @paul53
              Hello!

              Wo genau bekomme ich die Variable "data" her?
              Unter Aktionen habe ich keine Möglichkeit es zu nutzen bzw. finde ich es nicht.
              2024-04-03 11_39_43-javascript.jpg
              Habe auch schon die Variable manuell angelegt aber bei der Ausgabe kommt nur ein undefined.
              Hab den JS-Adapter auch schon mal neu gestartet - ohne Erfolg.
              Ich finde die Doku sollte bei neuen Funktionen dahingehend auch angepasst werden -> Aktionen
              Vielleicht könnte @klein0r (@haus-automatisierung ) das noch anpassen 😬 😀

              Vielen Dank im Voraus!

              paul53 haus-automatisierung 2 Replies Last reply Reply Quote 0
              • paul53
                paul53 @Thomas Schulze last edited by

                @thomas-schulze sagte: Wo genau bekomme ich die Variable "data" her?

                JS-Version 7.11.1:

                Blockly_temp.JPG

                1 Reply Last reply Reply Quote 1
                • haus-automatisierung
                  haus-automatisierung Developer Most Active @Thomas Schulze last edited by

                  @thomas-schulze sagte in JSON in Objekt/Datenpunkt umwandeln:

                  Ich finde die Doku sollte bei neuen Funktionen dahingehend auch angepasst werden -> Aktionen

                  Na dann mal los 🙂 Dreisprachig alle Screenshots neu zu erstellen ist schonmal ne super Aufgabe... Die könntest Du mir ja abnehmen, oder? Dann passe ich die Texte an.

                  Thomas Schulze 1 Reply Last reply Reply Quote 4
                  • Thomas Schulze
                    Thomas Schulze @haus-automatisierung last edited by

                    @haus-automatisierung
                    Denke das bekomm ich hin 😂
                    Also einfach Screenshots(de, en und ru) von den 9 Blöcken unter Aktionen?
                    Und wo soll ich die ablegen? In die Cloud oder via E-mail?

                    VG

                    haus-automatisierung 1 Reply Last reply Reply Quote 0
                    • haus-automatisierung
                      haus-automatisierung Developer Most Active @Thomas Schulze last edited by

                      @thomas-schulze Na wenn dann machen wir doch gleich die ganze Doku ordentlich und aktualisieren alle Screenshots, oder?

                      Thomas Schulze 1 Reply Last reply Reply Quote 0
                      • Thomas Schulze
                        Thomas Schulze @haus-automatisierung last edited by

                        @haus-automatisierung Ui. OK.
                        Also alle in IoBroker zur Verfügung stehenden Grafikblöcke?
                        Das wird dann aber frühestens ende nächster Woche was bei mir(2 Kinder + Frau + Haus + was man sonst noch so hat😬).
                        Ich schick dir ne PM wenn fertig.

                        VG

                        haus-automatisierung 1 Reply Last reply Reply Quote 0
                        • haus-automatisierung
                          haus-automatisierung Developer Most Active @Thomas Schulze last edited by

                          @thomas-schulze Alle Bilder, welche hier zu finden sind:

                          https://github.com/ioBroker/ioBroker.javascript/tree/master/docs/en/img

                          Am einfachsten per Pull Request. Dann steht auch am Ende dein Name dran 🙂

                          1 Reply Last reply Reply Quote 0
                          • D
                            Diamand2k22 @Codierknecht last edited by

                            @codierknecht

                            wie kann ich denn aus dem Tibber JSON den Verbrauch vom aktuellen Tag in einen Datenpunkt, z.b. alias.0.tibber.verbrauch_heute schreiben?
                            Das geht ja über die Konvertierfunktion, aber da muss ich ja dann noch zusätzlich das Datum mit dem aktuellen vergleichen oder wie lös ich das am besten?

                            [
                              {
                                "from": "2024-08-25T00:00:00.000+02:00",
                                "to": "2024-08-26T00:00:00.000+02:00",
                                "cost": 0.7771725066,
                                "unitPrice": 0.214985,
                                "unitPriceVAT": 0.034325,
                                "consumption": 3.615,
                                "consumptionUnit": "kWh",
                                "currency": "EUR"
                              },
                              {
                                "from": "2024-08-26T00:00:00.000+02:00",
                                "to": "2024-08-27T00:00:00.000+02:00",
                                "cost": 1.8533735325,
                                "unitPrice": 0.333161,
                                "unitPriceVAT": 0.053194,
                                "consumption": 5.563,
                                "consumptionUnit": "kWh",
                                "currency": "EUR"
                              },
                              {
                                "from": "2024-08-27T00:00:00.000+02:00",
                                "to": "2024-08-28T00:00:00.000+02:00",
                                "cost": 1.2193425678,
                                "unitPrice": 0.303018,
                                "unitPriceVAT": 0.048381,
                                "consumption": 4.024,
                                "consumptionUnit": "kWh",
                                "currency": "EUR"
                              },
                              {
                                "from": "2024-08-28T00:00:00.000+02:00",
                                "to": "2024-08-29T00:00:00.000+02:00",
                                "cost": 0.5764352146,
                                "unitPrice": 0.338085,
                                "unitPriceVAT": 0.05398,
                                "consumption": 1.705,
                                "consumptionUnit": "kWh",
                                "currency": "EUR"
                              },
                              {
                                "from": "2024-08-29T00:00:00.000+02:00",
                                "to": "2024-08-30T00:00:00.000+02:00",
                                "cost": 0.1608156004,
                                "unitPrice": 0.384726,
                                "unitPriceVAT": 0.061427,
                                "consumption": 0.418,
                                "consumptionUnit": "kWh",
                                "currency": "EUR"
                              },
                              {
                                "from": "2024-08-30T00:00:00.000+02:00",
                                "to": "2024-08-31T00:00:00.000+02:00",
                                "cost": 0.0520080932,
                                "unitPrice": 0.346721,
                                "unitPriceVAT": 0.055359,
                                "consumption": 0.15,
                                "consumptionUnit": "kWh",
                                "currency": "EUR"
                              },
                              {
                                "from": "2024-08-31T00:00:00.000+02:00",
                                "to": "2024-09-01T00:00:00.000+02:00",
                                "cost": 0.0644335496,
                                "unitPrice": 0.320565,
                                "unitPriceVAT": 0.051183,
                                "consumption": 0.201,
                                "consumptionUnit": "kWh",
                                "currency": "EUR"
                              }
                            ]
                            
                            paul53 1 Reply Last reply Reply Quote 0
                            • paul53
                              paul53 @Diamand2k22 last edited by

                              @diamand2k22 sagte: das Datum mit dem aktuellen vergleichen oder wie lös ich das am besten?

                              Steht der Verbrauch des letzten Tages nicht immer an letzter Stelle im Array? Dann ist keine Prüfung des Datums nötig.
                              Versuche es mal so:

                              Blockly_temp.JPG

                              D D 2 Replies Last reply Reply Quote 3
                              • D
                                Diamand2k22 @paul53 last edited by Diamand2k22

                                @paul53

                                Danke erstmal für das Blockly!
                                Würde das auch mit der JASON Parse Funktion mit dem alias converter gehen, dass ich nur den letzten Wert parse?

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

                                  @diamand2k22 sagte: mit dem alias converter gehen, dass ich nur den letzten Wert parse?

                                  JSON.parse(val).pop().consumption
                                  
                                  1 Reply Last reply Reply Quote 1
                                  • D
                                    dan11hh @paul53 last edited by

                                    @paul53 Hilfe! Ich hänge...
                                    Sonst bekomme ich meine Blocklys einigermaßen dazu, was ich machen möchte. Sobald ich aber JSON Werte auslesen möchte, scheitere ich regelmäßig. Das will ich nicht mehr.

                                    Hintergrund:
                                    Ich möchte verhindern, dass mein eAuto aus dem Speicher geladen wird. Also erstmal eine Überprüfung ob "Sofort Laden" in der Wallbox (OpenWB) aktiviert ist, dann soll der GridSetPoint des Batteriewechselrichters laufend der aktuellen Ladeleistung des Autos angepasst werden. Alle Werte sind per MQTT vorhanden. Ich scheitere aber schon an dem JSON Wert für den GridPoint. Der wird wie folgt angegeben:

                                    {"max":1000000.0,"min":-1000000.0,"value":-10.0}
                                    

                                    Ich würde nun gerne die -10 in einen Datenpunkt schreiben. Habe oben mal das Beispiel rudimentär nachgebaut um zu sehen was passiert. Klappt so natürlich nicht.

                                    Bildschirmfoto 2024-10-20 um 12.24.56.png

                                    Was mache ich falsch. Mit Listen habe ich leider auch noch nicht gearbeitet. 😞

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

                                      @dan11hh sagte: -10 in einen Datenpunkt schreiben.

                                      Das ist keine Liste, sondern ein einfaches Objekt.

                                      Blockly_temp.JPG

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

                                        @paul53 So easy!? Danke! Das hilft mir wirklich sehr. Woran erkenne ich ein Objekt? Das nur ein "Value-Wert" enthalten ist? Wie kann ich dann schreiben? Also in das Objekt? Möchte ja die -10 gegen einen anderen Wert austauschen...

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

                                          @dan11hh sagte: Woran erkenne ich ein Objekt?

                                          An den geschweiften Klammern. Eine Liste hat eckige Klammern.

                                          @dan11hh sagte in JSON in Objekt/Datenpunkt umwandeln:

                                          Wie kann ich dann schreiben? Also in das Objekt? Möchte ja die -10 gegen einen anderen Wert austauschen...

                                          Etwa so:

                                          Blockly_temp.JPG

                                          D 1 Reply Last reply Reply Quote 1
                                          • D
                                            dan11hh @paul53 last edited by dan11hh

                                            @paul53 @paul53
                                            Top. Danke. Das funktioniert!
                                            Es geht leider noch weiter:

                                            {"name": "Standard-Lade-Profil", "prio": true, "load_default": false, "et": {"active": true, "max_price": 0.00016}, "time_charging": {"active": false}, "chargemode": {"selected": "instant_charging", "pv_charging": {"min_soc_current": 7, "min_current": 0, "feed_in_limit": false, "min_soc": 20, "max_soc": 100}, "scheduled_charging": {}, "instant_charging": {"current": 32, "limit": {"selected": "none", "amount": 27000, "soc": 100}}}}
                                            

                                            Ich möchte überprüfen ob der Wert "instant_charging" ausgewählt ist. Dann brauch ich eine Liste, oder?
                                            So geht es leider nicht:

                                            Bildschirmfoto 2024-10-21 um 08.50.10.png

                                            Als Ergebnis hab ich immer 169. Warum auch immer...

                                            paul53 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            820
                                            Online

                                            31.7k
                                            Users

                                            79.9k
                                            Topics

                                            1.3m
                                            Posts

                                            17
                                            72
                                            13658
                                            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