Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. Am zeitformat zu 24h, aus strin convertieren

    NEWS

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker goes Matter ... Matter Adapter in Stable

    Am zeitformat zu 24h, aus strin convertieren

    This topic has been deleted. Only users with topic management privileges can see it.
    • J
      jumbo125 @mickym last edited by jumbo125

      @mickym
      wauw, danke! jsonata. damit habe ich ja leider keine erfahrung damit...
      aber das sieht ja sehr gut aus!

      jetzt müsste ich die uhrzeiten nur wieder in den text bekommen.

      Ich gehe um 0:20 am ins Bett, stehe um 7:30 am auf und komme um 18:00 von der Arbeit und um 22:15 bekam ich einen Anruf?
      
      mickym 1 Reply Last reply Reply Quote 0
      • mickym
        mickym Most Active @jumbo125 last edited by mickym

        @jumbo125 Du stellst mich vor Herausforderungen - aber ich hab es hingebracht. 😉

        c357a13d-5fd6-4fc6-82ee-4be8a732ca74-image.png

        <xml xmlns="https://developers.google.com/blockly/xml">
         <variables>
           <variable id="GJ2ndMW7LkTX2-FSt,}t">Text</variable>
         </variables>
         <block type="variables_set" id="dY2fb+(e-ad-Mt0RzlE7" x="88" y="13">
           <field name="VAR" id="GJ2ndMW7LkTX2-FSt,}t">Text</field>
           <value name="VALUE">
             <block type="text" id="Om7utVfK8cNM_$JPk#9T">
               <field name="TEXT">Ich gehe um 0:25             am ins Bett, stehe um 7:30 am auf und komme um 6:00 pm von der Arbeit und um 10:15 pm bekam ich einen Anruf?</field>
             </block>
           </value>
           <next>
             <block type="debug" id="_V/Z{KFSxQqO6/QbAfR{">
               <field name="Severity">log</field>
               <value name="TEXT">
                 <shadow type="text" id="YCV..)c*joVUy@zZLwVb">
                   <field name="TEXT">test</field>
                 </shadow>
                 <block type="variables_get" id="4`o;_qliwGpl((6pCp8p">
                   <field name="VAR" id="GJ2ndMW7LkTX2-FSt,}t">Text</field>
                 </block>
               </value>
               <next>
                 <block type="debug" id="VL|Yw*~6T`XUb[p=vgI,">
                   <field name="Severity">log</field>
                   <value name="TEXT">
                     <shadow type="text" id="WsKh+ZW^lV~+@X42W_%/">
                       <field name="TEXT">test</field>
                     </shadow>
                     <block type="convert_jsonata" id="Uv)~o/$!Gw8^,~3bYQ]!">
                       <value name="EXPRESSION">
                         <shadow type="text" id="/pneW,Oj2_RtmURW]ywK">
                           <field name="TEXT">(     $convert := function($v){(         $arr := $match($v.match,/(\d*\d):(\d\d\W*)([a,p]m)/).groups;         $number($arr[0]) + ($arr[2]="pm" ? 12 : 0) &amp; ":" &amp; $trim($arr[1])         )};     $replace($,/\d*\d:\d\d\W*[a,p]m/, $convert)  )</field>
                         </shadow>
                       </value>
                       <value name="TARGET">
                         <block type="variables_get" id="gDyOiuPM*CRsvabHkQw3">
                           <field name="VAR" id="GJ2ndMW7LkTX2-FSt,}t">Text</field>
                         </block>
                       </value>
                     </block>
                   </value>
                 </block>
               </next>
             </block>
           </next>
         </block>
        </xml>
        

        Der JSONATA-Code ist ein kleines Programm geworden.

        (
            $convert := function($v){(
                $arr := $match($v.match,/(\d*\d):(\d\d\W*)([a,p]m)/).groups;
                $number($arr[0]) + ($arr[2]="pm" ? 12 : 0) & ":" & $trim($arr[1])
                )};
            $replace($,/\d*\d:\d\d\W*[a,p]m/, $convert)
         )
        
        J 1 Reply Last reply Reply Quote 0
        • J
          jumbo125 @mickym last edited by

          @mickym
          wauw schut echt gut aus!!!!
          sind die mehrfachen leerzeichen for dem time value wichtig, damit es als uhrzeit erkennt wird? das habe ich leider nicht....
          mein text sieht bspw so aus:
          🟡 Warnstufe 2/4 Gewitterwarnung (Fr. 03:00 PM - Sa. 06:00 AM) Gewitter mit Sturmböen sind zu erwarten.

          aber ich kann es auch in php machen, falls alle stricke reißen....

          mickym 1 Reply Last reply Reply Quote 0
          • mickym
            mickym Most Active @jumbo125 last edited by mickym

            @jumbo125 hat mit den Leerzeichen nichts zu tun. Man muss es halt um die Großbuchstaben ergänzen bzw. bei den regulären Ausdrücken die Case-Insensitiv Option wählen.

            90493b07-c6f3-46c2-8922-33e3a76bdad2-image.png

            <xml xmlns="https://developers.google.com/blockly/xml">
             <variables>
               <variable id="GJ2ndMW7LkTX2-FSt,}t">Text</variable>
             </variables>
             <block type="variables_set" id="dY2fb+(e-ad-Mt0RzlE7" x="113" y="-112">
               <field name="VAR" id="GJ2ndMW7LkTX2-FSt,}t">Text</field>
               <value name="VALUE">
                 <block type="text" id="Om7utVfK8cNM_$JPk#9T">
                   <field name="TEXT">Ich gehe um 0:20 am ins Bett, stehe um 7:30 am auf und komme um 6:00 pm von der Arbeit und um 10:15 pm bekam ich einen Anruf?</field>
                 </block>
               </value>
               <next>
                 <block type="debug" id="_V/Z{KFSxQqO6/QbAfR{">
                   <field name="Severity">log</field>
                   <value name="TEXT">
                     <shadow type="text" id="YCV..)c*joVUy@zZLwVb">
                       <field name="TEXT">test</field>
                     </shadow>
                     <block type="variables_get" id="4`o;_qliwGpl((6pCp8p">
                       <field name="VAR" id="GJ2ndMW7LkTX2-FSt,}t">Text</field>
                     </block>
                   </value>
                   <next>
                     <block type="debug" id="VL|Yw*~6T`XUb[p=vgI,">
                       <field name="Severity">log</field>
                       <value name="TEXT">
                         <shadow type="text" id="WsKh+ZW^lV~+@X42W_%/">
                           <field name="TEXT">test</field>
                         </shadow>
                         <block type="convert_jsonata" id="Uv)~o/$!Gw8^,~3bYQ]!">
                           <value name="EXPRESSION">
                             <shadow type="text" id="/pneW,Oj2_RtmURW]ywK">
                               <field name="TEXT">(     $convert := function($v){(         $arr := $match($v.match,/(\d*\d):(\d\d\W*)([a,p]m)/i).groups;         $number($arr[0]) + (($arr[2]="pm" or $arr[2]="PM") ? 12 : 0) &amp; ":" &amp; $trim($arr[1])         )};     $replace($,/\d*\d:\d\d\W*[a,p]m/i, $convert)  )</field>
                             </shadow>
                           </value>
                           <value name="TARGET">
                             <block type="variables_get" id="gDyOiuPM*CRsvabHkQw3">
                               <field name="VAR" id="GJ2ndMW7LkTX2-FSt,}t">Text</field>
                             </block>
                           </value>
                         </block>
                       </value>
                       <next>
                         <block type="variables_set" id="oFp*1D5j*sC6=I,s[ofM">
                           <field name="VAR" id="GJ2ndMW7LkTX2-FSt,}t">Text</field>
                           <value name="VALUE">
                             <block type="text" id="HxT8VBlT2(=;H[K1EZP!">
                               <field name="TEXT">Warnstufe 2/4 Gewitterwarnung (Fr. 03:00 PM - Sa. 06:00 AM) Gewitter mit Sturmböen sind zu erwarten.</field>
                             </block>
                           </value>
                           <next>
                             <block type="debug" id="{fK|=RQ$v):,Nu)aiXwv">
                               <field name="Severity">log</field>
                               <value name="TEXT">
                                 <shadow type="text">
                                   <field name="TEXT">test</field>
                                 </shadow>
                                 <block type="variables_get" id="3LIlEGFkR46k~@YWN;uV">
                                   <field name="VAR" id="GJ2ndMW7LkTX2-FSt,}t">Text</field>
                                 </block>
                               </value>
                               <next>
                                 <block type="debug" id="4o$W[@s(d%y:QX;LPas#">
                                   <field name="Severity">log</field>
                                   <value name="TEXT">
                                     <shadow type="text">
                                       <field name="TEXT">test</field>
                                     </shadow>
                                     <block type="convert_jsonata" id="vHa5hu4.!?$H,3DEE7N,">
                                       <value name="EXPRESSION">
                                         <shadow type="text" id="5ViR*V^N;`,/,=8QxtP5">
                                           <field name="TEXT">(     $convert := function($v){(         $arr := $match($v.match,/(\d*\d):(\d\d\W*)([a,p]m)/i).groups;         $number($arr[0]) + (($arr[2]="pm" or $arr[2]="PM") ? 12 : 0) &amp; ":" &amp; $trim($arr[1])         )};     $replace($,/\d*\d:\d\d\W*[a,p]m/i, $convert)  )</field>
                                         </shadow>
                                       </value>
                                       <value name="TARGET">
                                         <block type="variables_get" id=")_!P`KR^sid,LzP;LfI{">
                                           <field name="VAR" id="GJ2ndMW7LkTX2-FSt,}t">Text</field>
                                         </block>
                                       </value>
                                     </block>
                                   </value>
                                 </block>
                               </next>
                             </block>
                           </next>
                         </block>
                       </next>
                     </block>
                   </next>
                 </block>
               </next>
             </block>
            </xml>
            

            ($convert := function($v){(
                $arr := $match($v.match,/(\d*\d):(\d\d\W*)([a,p]m)/i).groups;
                $number($arr[0]) + (($arr[2]="pm" or $arr[2]="PM") ? 12 : 0) & ":" & $trim($arr[1])
                )};     
            $replace($,/\d*\d:\d\d\W*[a,p]m/i, $convert))
            
            J 1 Reply Last reply Reply Quote 0
            • J
              jumbo125 @mickym last edited by

              @mickym
              Wahnsinn!!!!
              ich kenne die ausdrücke auch bei diversen string functionen von php und js. aber da muss ich so ehrlich sein und zugeben, dass ich da immer wieder nachlesen muss, da ich mit den ganzen Backslash, klein und großschreibungen immer durcheinander komme
              Danke dir!!!!!

              1 Reply Last reply Reply Quote 0
              • mickym
                mickym Most Active last edited by mickym

                Na ja, ich muss da auch ausprobieren. Aber sowohl bei JSONATA gibts eine try Seite und bei regulären Ausdrücken mehrere.JSONATA ist in meinem Augen eine Wahnsinnsbibliothek, die einem viel Codeschreiben abnimmt. Ich bin dazu gekommen, nicht weil ich Blockly sondern NodeRed nutze.

                J 1 Reply Last reply Reply Quote 0
                • J
                  jumbo125 @mickym last edited by

                  @mickym
                  danke. dachte ich mir schon aufgrund deines logos 🙂

                  mickym 1 Reply Last reply Reply Quote 0
                  • mickym
                    mickym Most Active @jumbo125 last edited by

                    @jumbo125 Hier schau mal, wenn Du dieses Fenster in der JSONTA Doku öffnest:

                    https://try.jsonata.org/WwOgkBnOf

                    kannst Du direkt ausprobieren und siehst das Ergebnis bei jedem Tastendruck.
                    Links die Eingabe, rechts oben Dein Code und rechts unten das Ergebnis:

                    130e187b-a8b9-4f0c-bca6-d6b96bc5bbf2-image.png

                    Ich kanns Dir nur empfehlen.

                    Zum Testen der regulären Ausdrücke verwende ich diese Seite: https://regex101.com/

                    Du hast damit auch immer Erklärungen und siehst Gruppen und Matches.

                    J 2 Replies Last reply Reply Quote 0
                    • J
                      jumbo125 @mickym last edited by

                      @mickym danke dir!

                      1 Reply Last reply Reply Quote 0
                      • J
                        jumbo125 @mickym last edited by

                        @mickym
                        Verzeih wenn ich lästig bin.
                        ich wollte mich mal mit regex etwas auseinandersetzten und dachte ich starte mit deinem code.....
                        aber da kommt gleich mal eine fehlermeldung bei der von dir empfohlenen seite..... könntest du mir einen tipp geben, bitte

                        Danke!
                        080552e2-1a57-4306-82d7-7a37107f0cbc-image.png

                        mickym 1 Reply Last reply Reply Quote 0
                        • mickym
                          mickym Most Active @jumbo125 last edited by mickym

                          @jumbo125 Es handelt sich um JSONATA und nicht um JSON. Also Dein Tool ist völlig verkehrt. Du musst den JSONATA Editor verwenden und meinen LInk aufrufen.

                          https://try.jsonata.org/WwOgkBnOf

                          Reguläre Ausdrücke regex - sind lediglich die Teile zwischen den beiden Schrägstrichen zum Beispiel:

                          /\d*\d:\d\d\W*[a,p]m/
                          

                          oder

                          /(\d*\d):(\d\d\W*)([a,p]m)/
                          

                          Wenn ich Dir den Code erklären soll, dann musst Du es halt sagen, dann gehen wir das Schritt für Schritt durch - aber dann musst Dir halt Zeit nehmen.

                          Wenn Du nur die regulären Ausdrücke testen willst, dann hier: https://regex101.com/r/6vvJNj/1

                          1 Reply Last reply Reply Quote 0
                          • mickym
                            mickym Most Active last edited by

                            @jumbo125 Oder innerhalb der comvert Funktion werden die 3 Gruppen aus dem amerikanischen Zeitformaten gebildet:

                            https://regex101.com/r/U54uq5/1

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

                            Support us

                            ioBroker
                            Community Adapters
                            Donate

                            874
                            Online

                            32.0k
                            Users

                            80.4k
                            Topics

                            1.3m
                            Posts

                            2
                            15
                            605
                            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