Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
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

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    15
    1
    834

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    681

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    1.9k

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

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
26 Beiträge 2 Kommentatoren 4.1k Aufrufe 2 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • 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
    schrieb am zuletzt editiert von 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 Antworten Letzte Antwort
    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 Offline
      mickymM Offline
      mickym
      Most Active
      schrieb am zuletzt editiert von
      #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 Antwort Letzte Antwort
      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 Offline
        mickymM Offline
        mickym
        Most Active
        schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
        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
          schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
          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 Offline
            mickymM Offline
            mickym
            Most Active
            schrieb am zuletzt editiert von
            #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 Antwort Letzte Antwort
            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
              schrieb am zuletzt editiert von 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 Antworten Letzte Antwort
              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 Offline
                mickymM Offline
                mickym
                Most Active
                schrieb am zuletzt editiert von
                #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 Antwort Letzte Antwort
                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 Offline
                  mickymM Offline
                  mickym
                  Most Active
                  schrieb am zuletzt editiert von
                  #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 Antwort Letzte Antwort
                  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
                    schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                    0
                    • Chris 1C Chris 1

                      @mickym Wow, spitze :+1: Kotau!

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

                      mickymM Offline
                      mickymM Offline
                      mickym
                      Most Active
                      schrieb am zuletzt editiert von
                      #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 Antwort Letzte Antwort
                      1
                      Antworten
                      • In einem neuen Thema antworten
                      Anmelden zum Antworten
                      • Älteste zuerst
                      • Neuste zuerst
                      • Meiste Stimmen


                      Support us

                      ioBroker
                      Community Adapters
                      Donate

                      879

                      Online

                      32.6k

                      Benutzer

                      82.0k

                      Themen

                      1.3m

                      Beiträge
                      Community
                      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                      ioBroker Community 2014-2025
                      logo
                      • Anmelden

                      • Du hast noch kein Konto? Registrieren

                      • Anmelden oder registrieren, um zu suchen
                      • Erster Beitrag
                        Letzter Beitrag
                      0
                      • Home
                      • Aktuell
                      • Tags
                      • Ungelesen 0
                      • Kategorien
                      • Unreplied
                      • Beliebt
                      • GitHub
                      • Docu
                      • Hilfe