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.
    • 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
                                          • Codierknecht
                                            Codierknecht Developer Most Active @Hans_M last edited by

                                            @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 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            633
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

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