Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. [gelöst] Blockly: JSON mit Regex aus Variable auslesen

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    5
    1
    40

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.4k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.3k

[gelöst] Blockly: JSON mit Regex aus Variable auslesen

Scheduled Pinned Locked Moved Skripten / Logik
26 Posts 2 Posters 4.0k Views 2 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • mickymM mickym

    @chris-1 sagte in [gelöst] Blockly: JSON mit Regex aus Variable auslesen:

    Das Script ist für mich der erste Verteiler, welcher vom Tasmota-Zigbee-Gateway rein kommenden Sachen verteilen soll.

    Tja Du siehst, wenn man gleich das Ziel ausformuliert, dann bekommt man auch gleich einen Vorschlag.

    Chris 1C Offline
    Chris 1C Offline
    Chris 1
    wrote on last edited by Chris 1
    #15

    @mickym Nochmal eine Nachfrage zu JsonATA

    Wie greife ich auf das x-te (hier 2tes) Elemente-Paar im JSON String zu?
    Habe schon alle möglichen Tutorials hoch und runter gesucht, aber hierzu nichts gefunden.

    Beispiel für empfangene Daten:

    {"Device":"0x0D73","EF00/0214":83,"Endpoint":1,"LinkQuality":136}
    {"Device":"0x0D73","EF00/0215":469,"Endpoint":1,"LinkQuality":136}
    {"Device":"0x0D73","EF00/0216":749,"Endpoint":1,"LinkQuality":136}
    {"Device":"0x0D73","EF00/0202":295,"Endpoint":1,"LinkQuality":136}
    

    Müsste ich das ggf über sowas wie "$spread()" lösen?

    Schon mal vorab herzlichen Dank
    Chris

    bpi-m5 (ioBroker), rock3a (postgreSQL), lamobo R1 (OpenWRT), Tasmota-ZB, Tasmota-IR

    mickymM 1 Reply Last reply
    0
    • Chris 1C Chris 1

      @mickym Nochmal eine Nachfrage zu JsonATA

      Wie greife ich auf das x-te (hier 2tes) Elemente-Paar im JSON String zu?
      Habe schon alle möglichen Tutorials hoch und runter gesucht, aber hierzu nichts gefunden.

      Beispiel für empfangene Daten:

      {"Device":"0x0D73","EF00/0214":83,"Endpoint":1,"LinkQuality":136}
      {"Device":"0x0D73","EF00/0215":469,"Endpoint":1,"LinkQuality":136}
      {"Device":"0x0D73","EF00/0216":749,"Endpoint":1,"LinkQuality":136}
      {"Device":"0x0D73","EF00/0202":295,"Endpoint":1,"LinkQuality":136}
      

      Müsste ich das ggf über sowas wie "$spread()" lösen?

      Schon mal vorab herzlichen Dank
      Chris

      mickymM Online
      mickymM Online
      mickym
      Most Active
      wrote on last edited by mickym
      #16

      @chris-1 Das steht ddoch niemals so alleine da? - Entweder ist das ein Array mit Objekten (also das ganze in eckigen Klammern und mit Kommas?) oder möchtest Du auf den Wert EF00/0214 zugreifen?

      So steht es aber mit Sicherheit nirgends.

      Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

      Chris 1C 1 Reply Last reply
      0
      • mickymM mickym

        @chris-1 Das steht ddoch niemals so alleine da? - Entweder ist das ein Array mit Objekten (also das ganze in eckigen Klammern und mit Kommas?) oder möchtest Du auf den Wert EF00/0214 zugreifen?

        So steht es aber mit Sicherheit nirgends.

        Chris 1C Offline
        Chris 1C Offline
        Chris 1
        wrote on last edited by Chris 1
        #17

        @mickym Ja, ich möchte diese (AirQuality) Werte unter "EF00/02xx" selektiv zugreifen.

        Und nein, das ist so kein Array, sonsern beispielhaft aus dem Log heraus geschnippelt. Es kommt immer nur ein JSON an.

        bpi-m5 (ioBroker), rock3a (postgreSQL), lamobo R1 (OpenWRT), Tasmota-ZB, Tasmota-IR

        mickymM 2 Replies Last reply
        0
        • Chris 1C Chris 1

          @mickym Ja, ich möchte diese (AirQuality) Werte unter "EF00/02xx" selektiv zugreifen.

          Und nein, das ist so kein Array, sonsern beispielhaft aus dem Log heraus geschnippelt. Es kommt immer nur ein JSON an.

          mickymM Online
          mickymM Online
          mickym
          Most Active
          wrote on last edited by
          #18

          @chris-1 Und diese Objekte sind in einem Array oder willst Du jetzt nur aus einem solchen Wert EF00/02xx zugreifen?

          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

          1 Reply Last reply
          0
          • Chris 1C Chris 1

            @mickym Ja, ich möchte diese (AirQuality) Werte unter "EF00/02xx" selektiv zugreifen.

            Und nein, das ist so kein Array, sonsern beispielhaft aus dem Log heraus geschnippelt. Es kommt immer nur ein JSON an.

            mickymM Online
            mickymM Online
            mickym
            Most Active
            wrote on last edited by mickym
            #19

            @chris-1 sagte in [gelöst] Blockly: JSON mit Regex aus Variable auslesen:

            @mickym Ja, ich möchte diese (AirQuality) Werte unter "EF00/02xx" selektiv zugreifen.

            Und nein, das ist so kein Array, sonsern beispielhaft aus dem Log heraus geschnippelt. Es kommt immer nur ein JSON an.

            Dann verstehe ich Dein Problem glaube ich nicht???

            a48483f3-e848-47b3-bb2f-f71dd93a664b-image.png

            Oder willst Du das Attribut mit JSONATA extrahieren?

            Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

            Chris 1C 1 Reply Last reply
            0
            • mickymM mickym

              @chris-1 sagte in [gelöst] Blockly: JSON mit Regex aus Variable auslesen:

              @mickym Ja, ich möchte diese (AirQuality) Werte unter "EF00/02xx" selektiv zugreifen.

              Und nein, das ist so kein Array, sonsern beispielhaft aus dem Log heraus geschnippelt. Es kommt immer nur ein JSON an.

              Dann verstehe ich Dein Problem glaube ich nicht???

              a48483f3-e848-47b3-bb2f-f71dd93a664b-image.png

              Oder willst Du das Attribut mit JSONATA extrahieren?

              Chris 1C Offline
              Chris 1C Offline
              Chris 1
              wrote on last edited by Chris 1
              #20

              @mickym Der Sensor liefert 6? unterschiedliche Werte.
              Diese stehen an 2ter Stelle des JSON in der Form "EF00/02<xx>" : Value

              Ich möchte also a) wissen welcher Wert (zB "EF00/0212") übermittelt wird,
              b) Value ergibt sich danach leichter.

              bpi-m5 (ioBroker), rock3a (postgreSQL), lamobo R1 (OpenWRT), Tasmota-ZB, Tasmota-IR

              mickymM 1 Reply Last reply
              0
              • Chris 1C Chris 1

                @mickym Der Sensor liefert 6? unterschiedliche Werte.
                Diese stehen an 2ter Stelle des JSON in der Form "EF00/02<xx>" : Value

                Ich möchte also a) wissen welcher Wert (zB "EF00/0212") übermittelt wird,
                b) Value ergibt sich danach leichter.

                mickymM Online
                mickymM Online
                mickym
                Most Active
                wrote on last edited by
                #21

                @chris-1 Ok das ist schon etwas herausfordernder, aber es beginnt immer mit EF00/02?

                Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                Chris 1C 1 Reply Last reply
                1
                • mickymM mickym

                  @chris-1 Ok das ist schon etwas herausfordernder, aber es beginnt immer mit EF00/02?

                  Chris 1C Offline
                  Chris 1C Offline
                  Chris 1
                  wrote on last edited by Chris 1
                  #22

                  @mickym Ja

                  Ob man dies ggf einfacher als "SubString" extrahiert?
                  Bis einschliesslich SubString-ID hat es ja immer die selbe Länge...

                  bpi-m5 (ioBroker), rock3a (postgreSQL), lamobo R1 (OpenWRT), Tasmota-ZB, Tasmota-IR

                  mickymM 2 Replies Last reply
                  0
                  • Chris 1C Chris 1

                    @mickym Ja

                    Ob man dies ggf einfacher als "SubString" extrahiert?
                    Bis einschliesslich SubString-ID hat es ja immer die selbe Länge...

                    mickymM Online
                    mickymM Online
                    mickym
                    Most Active
                    wrote on last edited by
                    #23

                    @chris-1 Ich habs gleich - etwas Geduld bitte

                    Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                    1 Reply Last reply
                    1
                    • Chris 1C Chris 1

                      @mickym Ja

                      Ob man dies ggf einfacher als "SubString" extrahiert?
                      Bis einschliesslich SubString-ID hat es ja immer die selbe Länge...

                      mickymM Online
                      mickymM Online
                      mickym
                      Most Active
                      wrote on last edited by
                      #24

                      @chris-1 So hier die Lösung:

                      03825a4b-a92d-475c-a2d5-190e066d45db-image.png

                      Der JSONATA Ausdruck erzeugt ein neues Objekt mit den Attributen key und value auf dass Du dann normal mit den Blockly Attributen zugreifen kannst.

                      Der JSONATA Ausdruck lautet:

                      $.$sift(function($v, $k) {$k ~> /^EF00\/02/}){"key": $keys(),"value":$.*}
                      

                      Hier das Ganze zum Import und Testen

                      <xml xmlns="https://developers.google.com/blockly/xml">
                       <variables>
                         <variable id=";po#/$v(8.UbHdHNkx[6">Objekt</variable>
                       </variables>
                       <block type="variables_set" id="W@hg1tE.68iwuYzK2!uN" x="-1263" y="-835">
                         <field name="VAR" id=";po#/$v(8.UbHdHNkx[6">Objekt</field>
                         <value name="VALUE">
                           <block type="convert_json2object" id="(0IX6:]p|*y3zL7||zBw">
                             <value name="VALUE">
                               <block type="text" id="cj9Q,eiBn6QVld(V7kV2">
                                 <field name="TEXT">{"Device":"0x0D73","EF00/0214":83,"Endpoint":1,"LinkQuality":136}</field>
                               </block>
                             </value>
                           </block>
                         </value>
                         <next>
                           <block type="variables_set" id="9+M],oEz;U^a+N[vt#`g">
                             <field name="VAR" id=";po#/$v(8.UbHdHNkx[6">Objekt</field>
                             <value name="VALUE">
                               <block type="convert_jsonata" id="N^%KxZ{%,3GmzsQvn+c(">
                                 <value name="EXPRESSION">
                                   <shadow type="text" id="g]4!|~f.(-MAU?:dXi)?">
                                     <field name="TEXT">$.$sift(function($v, $k) {$k ~&gt; /^EF00\/02/}){"key": $keys(),"value":$.*}</field>
                                   </shadow>
                                 </value>
                                 <value name="TARGET">
                                   <block type="variables_get" id="70c4ESN`7hWTUT-(49y!">
                                     <field name="VAR" id=";po#/$v(8.UbHdHNkx[6">Objekt</field>
                                   </block>
                                 </value>
                               </block>
                             </value>
                             <next>
                               <block type="debug" id="n7%]r/8E9.7*=Yc/SwqD">
                                 <field name="Severity">log</field>
                                 <value name="TEXT">
                                   <shadow type="text" id="_OZ+{6nC[=m9DhEs.K[]">
                                     <field name="TEXT">test</field>
                                   </shadow>
                                   <block type="variables_get" id="-Q_F|i0gY.V`q1:_DGZj">
                                     <field name="VAR" id=";po#/$v(8.UbHdHNkx[6">Objekt</field>
                                   </block>
                                 </value>
                                 <next>
                                   <block type="debug" id="$mUXBli_e}bd4hA?t2Ls">
                                     <field name="Severity">log</field>
                                     <value name="TEXT">
                                       <shadow type="text" id="+:$J:sSMpe_Z8M4p0YYN">
                                         <field name="TEXT">test</field>
                                       </shadow>
                                       <block type="get_attr" id="s8LY=qPscr-My@k|c-.l">
                                         <value name="PATH">
                                           <shadow type="text" id="[}UnHmrmR:{xN!J)0KlB">
                                             <field name="TEXT">key</field>
                                           </shadow>
                                         </value>
                                         <value name="OBJECT">
                                           <block type="variables_get" id="R_[5TjBBSEIu*I=Xk-SJ">
                                             <field name="VAR" id=";po#/$v(8.UbHdHNkx[6">Objekt</field>
                                           </block>
                                         </value>
                                       </block>
                                     </value>
                                     <next>
                                       <block type="debug" id="$|g.Yy_[6Qity9{lgt{#">
                                         <field name="Severity">log</field>
                                         <value name="TEXT">
                                           <shadow type="text" id="3Ym?y,.KIM6gAqn4!z4e">
                                             <field name="TEXT">test</field>
                                           </shadow>
                                           <block type="get_attr" id="d_i|9]ucU.,jP7d;WRR)">
                                             <value name="PATH">
                                               <shadow type="text" id=",eAl@_h]7=Nna@c5r-3t">
                                                 <field name="TEXT">value</field>
                                               </shadow>
                                             </value>
                                             <value name="OBJECT">
                                               <block type="variables_get" id="r|%-}(FGnhMNQwQaC/rH">
                                                 <field name="VAR" id=";po#/$v(8.UbHdHNkx[6">Objekt</field>
                                               </block>
                                             </value>
                                           </block>
                                         </value>
                                       </block>
                                     </next>
                                   </block>
                                 </next>
                               </block>
                             </next>
                           </block>
                         </next>
                       </block>
                      </xml>
                      

                      Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                      Chris 1C 1 Reply Last reply
                      1
                      • mickymM mickym

                        @chris-1 So hier die Lösung:

                        03825a4b-a92d-475c-a2d5-190e066d45db-image.png

                        Der JSONATA Ausdruck erzeugt ein neues Objekt mit den Attributen key und value auf dass Du dann normal mit den Blockly Attributen zugreifen kannst.

                        Der JSONATA Ausdruck lautet:

                        $.$sift(function($v, $k) {$k ~> /^EF00\/02/}){"key": $keys(),"value":$.*}
                        

                        Hier das Ganze zum Import und Testen

                        <xml xmlns="https://developers.google.com/blockly/xml">
                         <variables>
                           <variable id=";po#/$v(8.UbHdHNkx[6">Objekt</variable>
                         </variables>
                         <block type="variables_set" id="W@hg1tE.68iwuYzK2!uN" x="-1263" y="-835">
                           <field name="VAR" id=";po#/$v(8.UbHdHNkx[6">Objekt</field>
                           <value name="VALUE">
                             <block type="convert_json2object" id="(0IX6:]p|*y3zL7||zBw">
                               <value name="VALUE">
                                 <block type="text" id="cj9Q,eiBn6QVld(V7kV2">
                                   <field name="TEXT">{"Device":"0x0D73","EF00/0214":83,"Endpoint":1,"LinkQuality":136}</field>
                                 </block>
                               </value>
                             </block>
                           </value>
                           <next>
                             <block type="variables_set" id="9+M],oEz;U^a+N[vt#`g">
                               <field name="VAR" id=";po#/$v(8.UbHdHNkx[6">Objekt</field>
                               <value name="VALUE">
                                 <block type="convert_jsonata" id="N^%KxZ{%,3GmzsQvn+c(">
                                   <value name="EXPRESSION">
                                     <shadow type="text" id="g]4!|~f.(-MAU?:dXi)?">
                                       <field name="TEXT">$.$sift(function($v, $k) {$k ~&gt; /^EF00\/02/}){"key": $keys(),"value":$.*}</field>
                                     </shadow>
                                   </value>
                                   <value name="TARGET">
                                     <block type="variables_get" id="70c4ESN`7hWTUT-(49y!">
                                       <field name="VAR" id=";po#/$v(8.UbHdHNkx[6">Objekt</field>
                                     </block>
                                   </value>
                                 </block>
                               </value>
                               <next>
                                 <block type="debug" id="n7%]r/8E9.7*=Yc/SwqD">
                                   <field name="Severity">log</field>
                                   <value name="TEXT">
                                     <shadow type="text" id="_OZ+{6nC[=m9DhEs.K[]">
                                       <field name="TEXT">test</field>
                                     </shadow>
                                     <block type="variables_get" id="-Q_F|i0gY.V`q1:_DGZj">
                                       <field name="VAR" id=";po#/$v(8.UbHdHNkx[6">Objekt</field>
                                     </block>
                                   </value>
                                   <next>
                                     <block type="debug" id="$mUXBli_e}bd4hA?t2Ls">
                                       <field name="Severity">log</field>
                                       <value name="TEXT">
                                         <shadow type="text" id="+:$J:sSMpe_Z8M4p0YYN">
                                           <field name="TEXT">test</field>
                                         </shadow>
                                         <block type="get_attr" id="s8LY=qPscr-My@k|c-.l">
                                           <value name="PATH">
                                             <shadow type="text" id="[}UnHmrmR:{xN!J)0KlB">
                                               <field name="TEXT">key</field>
                                             </shadow>
                                           </value>
                                           <value name="OBJECT">
                                             <block type="variables_get" id="R_[5TjBBSEIu*I=Xk-SJ">
                                               <field name="VAR" id=";po#/$v(8.UbHdHNkx[6">Objekt</field>
                                             </block>
                                           </value>
                                         </block>
                                       </value>
                                       <next>
                                         <block type="debug" id="$|g.Yy_[6Qity9{lgt{#">
                                           <field name="Severity">log</field>
                                           <value name="TEXT">
                                             <shadow type="text" id="3Ym?y,.KIM6gAqn4!z4e">
                                               <field name="TEXT">test</field>
                                             </shadow>
                                             <block type="get_attr" id="d_i|9]ucU.,jP7d;WRR)">
                                               <value name="PATH">
                                                 <shadow type="text" id=",eAl@_h]7=Nna@c5r-3t">
                                                   <field name="TEXT">value</field>
                                                 </shadow>
                                               </value>
                                               <value name="OBJECT">
                                                 <block type="variables_get" id="r|%-}(FGnhMNQwQaC/rH">
                                                   <field name="VAR" id=";po#/$v(8.UbHdHNkx[6">Objekt</field>
                                                 </block>
                                               </value>
                                             </block>
                                           </value>
                                         </block>
                                       </next>
                                     </block>
                                   </next>
                                 </block>
                               </next>
                             </block>
                           </next>
                         </block>
                        </xml>
                        

                        Chris 1C Offline
                        Chris 1C Offline
                        Chris 1
                        wrote on last edited by Chris 1
                        #25

                        @mickym Wow, spitze :+1: Kotau!

                        Freu-Freu-Freu... läuft!

                        bpi-m5 (ioBroker), rock3a (postgreSQL), lamobo R1 (OpenWRT), Tasmota-ZB, Tasmota-IR

                        mickymM 1 Reply Last reply
                        0
                        • Chris 1C Chris 1

                          @mickym Wow, spitze :+1: Kotau!

                          Freu-Freu-Freu... läuft!

                          mickymM Online
                          mickymM Online
                          mickym
                          Most Active
                          wrote on last edited by
                          #26

                          @chris-1 Mit Node-Red würdest Du Dir halt soviel leichter tun, als mit dem Puzzeln - aber ehrlich gesagt, bin ich es langsam müde mich da zu wiederholen. ;)

                          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                          1 Reply Last reply
                          1
                          Reply
                          • Reply as topic
                          Log in to reply
                          • Oldest to Newest
                          • Newest to Oldest
                          • Most Votes


                          Support us

                          ioBroker
                          Community Adapters
                          Donate

                          592

                          Online

                          32.5k

                          Users

                          81.7k

                          Topics

                          1.3m

                          Posts
                          Community
                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                          ioBroker Community 2014-2025
                          logo
                          • Login

                          • Don't have an account? Register

                          • Login or register to search.
                          • First post
                            Last post
                          0
                          • Home
                          • Recent
                          • Tags
                          • Unread 0
                          • Categories
                          • Unreplied
                          • Popular
                          • GitHub
                          • Docu
                          • Hilfe