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.
    • 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
                          • 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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            698
                                            Online

                                            31.7k
                                            Users

                                            79.9k
                                            Topics

                                            1.3m
                                            Posts

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