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

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    JSON in Objekt/Datenpunkt umwandeln

    This topic has been deleted. Only users with topic management privileges can see it.
    • 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
                    • paul53
                      paul53 @dan11hh last edited by paul53

                      @dan11hh sagte: Dann brauch ich eine Liste, oder?

                      Das ist ein strukturiertes Objekt.

                      @dan11hh sagte in JSON in Objekt/Datenpunkt umwandeln:

                      ob der Wert "instant_charging" ausgewählt ist.

                      Attribut: "chargemode.selected"

                      Blockly_temp.JPG

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

                        @paul53 Danke DIr. Wieder was gelernt. So langsam verstehe ich, glaube ich, das Prinzip. Danke für die Geduld. Hoffe ich strapaziere diese nicht über, wenn ich nochmal fragen muss:
                        Mein Skript funktioniert, bis auf die Übergabe als JSON. Also ich bekomme in den letzten Datenpunkt nur den Wert reingeschrieben, also bspw. 50. Ich brauche aber ja: {"value":50} Hast du eine Idee?

                        Bildschirmfoto 2024-10-21 um 21.54.33.png

                        Codierknecht paul53 2 Replies Last reply Reply Quote 0
                        • Codierknecht
                          Codierknecht Developer Most Active @dan11hh last edited by

                          @dan11hh sagte in JSON in Objekt/Datenpunkt umwandeln:

                          Hast du eine Idee?

                          fe9e0d5f-cc9d-48c7-bbe2-8c19af1f59d2-grafik.png

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

                            @dan11hh sagte: Hast du eine Idee?

                            Das Objekt ist nicht minSoC, sondern AktuellerBatterieSoC. Außerdem kann man unmittelbar nach dem Schreiben in einen DP ihn nicht gleich wieder einlesen, da "aktualisiere" asynchron ausgeführt wird.
                            Lese "value" in die Variable minSoC ein und verwende diese weiter.

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

                              @paul53 sagte in JSON in Objekt/Datenpunkt umwandeln:

                              Außerdem kann man unmittelbar nach dem Schreiben in einen DP ihn nicht gleich wieder einlesen, da "aktualisiere" asynchron ausgeführt wird.

                              Ahh das wusste ich noch nicht.

                              Bei mir sieht es jetzt so aus:

                              Bildschirmfoto 2024-10-22 um 09.10.38.png

                              Ich bekomme aber als Ausgabe:

                              "{\"value\":22.5}"
                              

                              Also die Spiegelstriche sind überflüssig. Wo kommen die her?

                              Danke für die Hilfe!

                              @Codierknecht Danke! Mit Debug Info geht es schneller 😉 Ausgabe dazu siehe oben.

                              BananaJoe Codierknecht paul53 3 Replies Last reply Reply Quote 0
                              • BananaJoe
                                BananaJoe Most Active @dan11hh last edited by

                                @dan11hh sagte in JSON in Objekt/Datenpunkt umwandeln:

                                Also die Spiegelstriche sind überflüssig. Wo kommen die her?

                                Naja, die sind in diesem Fall nicht überflüssig weil die ganze Ausgabe ja selbst in " steht. Dann müssen die inneren "Escaped" werden, das macht man mit Spiegelstrichen.

                                Beides ist also richtig:

                                "{\"value\":22.5}"
                                {"value":22.5}
                                

                                Ist das die Debug Ausgabe? Dann könnte das beim Umwandeln in einen String passieren

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

                                  @dan11hh
                                  Bau Dir für die Ausgabe ein neues Objekt - so wie in meinem Beispiel.
                                  Du konvertierst da auch viel zu oft hin und her und liest weiterhin einen Wert, den Du gerade erst geschrieben hat.

                                  Versuch's mal auf die Art:

                                  3a86a256-b99d-4b4f-917a-2818dc5e8b5a-image.png

                                  Wenn's nicht funktioniert, poste mal hier das JSON aus dem Trigger, damit wir das nachstellen und testen können.

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

                                    @dan11hh sagte: Bei mir sieht es jetzt so aus:

                                    Sehr chaotisch.
                                    Soll der Wert von "value" nur aufgerundet in den MinimalenEntladeSoC geschrieben werden?

                                    Blockly_temp.JPG

                                    EDIT: Mit sinnvollen Variablenbezeichnern macht man sich das Leben einfacher.

                                    Blockly_temp.JPG

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

                                      @paul53
                                      Eigentlich will ich etwas ganz einfachers:

                                      Ich möchte, ausgelöst durch den Trigger "Sofort Laden", dass der AktuelleBatterieSOC den MinimalenEntladeSoC überschreibt.

                                      Das war es eigentlich schon. Wären die Werte nicht alle als JSON abgespeichert, hätte ich das schon hinbekommen. Aber so 😧

                                      Hintergrund ist, dass ich, wenn die Wallbox auf Sofort-Laden geht, der Hausspeicher nicht entladen wird, sondern nur aus dem Netz gezogen wird.

                                      Das Erkennen des "Sofort-Ladens" klappt ja auch schon. Nur das schreiben des AktuellenSoC in den MinimalenEntladeSoC nicht.

                                      Ich probiere jetzt mal deinen EDIT aus.

                                      EDIT:
                                      Ja, jetzt klappt es. 1000DANK! Ich arbeite fast nie mit Variable, deshalb habe ich, glaube ich, den ersten Versuch vermurkst. Will ich mir gleich nochmal angucken.

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

                                        Hallo habe folgendes Problem:

                                        Möchte aus einem Datenpunkt vom mqtt adapter einen Wert extrahieren, in diesem Fall die Spannung.
                                        Der Wert vom Datenpunkt ist z.B.:

                                        {"id": 100,"voltage":1.28}
                                        

                                        Ich möchte den Wert der Spannung in einen eigenen Datenpunkt schreiben.
                                        Mein Blocklyversuch sieht jetzt so aus
                                        Unbenannt.PNG

                                        Als Ausgabe bekomme ich leider nur folgendes: { val: undefined, ack: true }

                                        Kenne mich da zu wenig aus, hat jemand eine Idee?

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

                                          @hans_m sagte: Spannung in einen eigenen Datenpunkt schreiben.

                                          Blockly_temp.JPG

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

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

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            567
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

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