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

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    JSON in Objekt/Datenpunkt umwandeln

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

                  @codierknecht verstanden...vielen Dank

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

                    Ich hätte da auch mal eine Frage.
                    Ich habe im DP folgende Werte für die Spannungswerte der einzelnen Zellen meines BKW Akkus.

                    {"cells":[3.397,3.397,3.399,3.398,3.401,3.4,3.401,3.391,3.394,3.392,3.394,3.395,3.396,3.396],"min":3.391,"max":3.401,"avg":3.3965}
                    

                    Wie bekomme ich diese in einzelne DP um sie zu visualisieren?

                    Gruß 5tift

                    Homoran 1 Reply Last reply Reply Quote 0
                    • Homoran
                      Homoran Global Moderator Administrators @5tift last edited by

                      @5tift mal als Anregung
                      Screenshot_20250507-151211_Firefox.jpg

                      statt debug in entsprechende Datenpunkte schreiben

                      1 Reply Last reply Reply Quote 0
                      • Homoran
                        Homoran Global Moderator Administrators last edited by

                        Screenshot_20250507-152201_Firefox.jpg

                        Datenpunkte selber anlegen und Variable entsprechend ändern

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

                          @5tift sagte in JSON in Objekt/Datenpunkt umwandeln:

                          Wie bekomme ich diese in einzelne DP um sie zu visualisieren?

                          Entweder per Script, so wie @Homoran es zeigt, oder Du legst Dir für jede Zelle einen Alias an. Dann geht das auch ohne Script.
                          https://forum.iobroker.net/topic/70481/blockly-for-dummies-starthilfe-und-tipps/12

                          Die Konvertierungen würden so aussehen:

                          JSON.parse(val).cells[0]
                          JSON.parse(val).cells[1]
                          JSON.parse(val).cells[2]
                          ...
                          

                          e020c0a4-d468-4450-91ec-cd96f9f15b03-image.png

                          1 Reply Last reply Reply Quote 0
                          • 5
                            5tift @Homoran last edited by

                            @homoran
                            Vielen Dank für den schnellen Input, werd mal versuchen das nachzubauen 😊

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

                            Support us

                            ioBroker
                            Community Adapters
                            Donate

                            990
                            Online

                            31.7k
                            Users

                            79.7k
                            Topics

                            1.3m
                            Posts

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