Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Tester
    4. Adapter - Parser (regEx)

    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

    Adapter - Parser (regEx)

    This topic has been deleted. Only users with topic management privileges can see it.
    • G
      Gürol last edited by

      @Kunibert:

      Weiß jemand, wo hier der Fehler liegt bzw. wie ich eine vorhergehende Klasse einschränke? ` Hallo David,

      versuchs mal damit:

      LEISTUNGSAUFNAHME<\/th><\/tr>\s+\n\s+VD HEIZEN TAG<\/td>\n\s+(\d+,\d)
      

      Gruß

      Gürol

      1 Reply Last reply Reply Quote 0
      • K
        Kunibert last edited by

        Hallo Gürol,

        jetzt hab ichs kapiert 🙂

        Dann eine allerletzte Frage (versprochen! 😉 😞

        Wenn ich noch den Wert VD WARMWASSER TAG auslesen möchte aus der Klasse Leistungsaufnahme , muss ich dann neun Zeilenbrüche mit allen davorhergenden Werten hinter die Klasse Leistungsaufnahme einfügen oder geht das eleganter? Das funktioniert bei mir nicht. Oder gibt es da etwas eleganteres?

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

          https://regex101.com kennst du?

          Da fügst du deinen Quelltext in das große Fenster ein, stellst links auf JavaScript und kannst dich dann nach Herzenslust in dem Eingabefeld austoben.

          Gruß

          Rainer

          1 Reply Last reply Reply Quote 0
          • S
            starfish last edited by

            hallo,

            ich suche die Regex um aus folgendem Textfile das 99.Wort nach dem 98. space-Zeichen auszulesen. geht das überhaupt?

            12345 4.7 1.7 118 2.4 94 975.5 4.8 12.4 12.4 0.017 0.026 21.3 26 0.0 5 0.0 0 0 0.3 60.0 -66.7 52.2 -64.4 -100.0 -100.0 -100 -100 -100 14 45 43 -14:45:43 0 0 3 1 100 100 100 100 100 100 100 -0.0 0.7 5.3 2.3 5 Recent_showers -0.1 4.3 4.3 7.8 7.8 7.8 7.0 6.1 6.1 5.2 4.3 3.5 2.6 2.6 3.5 4.3 2.6 1.7 1.7 0.9 1.7 29.6 1.6 357.4 3/1/2018 4.3 0.6 3.5 -3.6 0.0 10.3 13.1 10.3 12.6 11.9 12.6 12.0 8.4 12.6 5.1 2.4 2.5 2.5 2.5 2.4 2.4 2.4 2.4 2.4 2.4 4.3 4.3 4.3 4.3 4.6 4.6 4.6 4.8 4.8 4.8 5.3 2.3 2.4 21.5 0 --- --- 115 0 0 -100.0 -100.0 -100 0 0 0 0 0.0 21.4 21.0 -0.4 998.6 975.4 23 14:05 08:28 2.9 -5.2 4.2 1.4 8 2018 0.0 1 1 1 117 122 103 115 114 113 108 106 120 118 0.0 255.0 9.7 2.1 0.00000 0.00000 4.1 94 88 4.8 12:19 - - - - - - 308.1 !!C10.37R74!! 
            

            Es handelt sich um die clientraw.txt - Ausgabe einer Oregon-Scientific Wetterstation.

            gruss

            /starfish

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

              Wenn du noch die Güte hättest den Wert dieser Zahl in diesem Beispiel zu nennen, dann könnte ich es bei regex101.com mal versuchen.

              Ich verzähle mich nur dauernd.

              Gruß

              Rainer

              1 Reply Last reply Reply Quote 0
              • S
                starfish last edited by

                hallo Rainer,

                es handelt sich um die 2.4 im letzten Drittel 2.4 21.5 0 –- --- aber eigentlich könnte man irgendeine Zahl im String nehmen, die wechseln ja ständig, also kann man nichts so richtig als Startpunkt nehmen. Ich hab übrigens auch im Simulator rumgepröbelt, ohne Erfolg - aber das will nichts heissen.

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

                  UNter der Bedingung, dass da hinter immer dir drei Striche stehen –-

                  (\d*\.\d)\s\d*\.\d\s\d ---
                  
                  1 Reply Last reply Reply Quote 0
                  • S
                    starfish last edited by

                    Danke Rainer - clevere Lösung. Aber irgendwie zu früh gefreut , die 3 Striche sind für den Datenpunkt "Time Last Lightning Strike" . Ohne Blitzschlag wirds funktionieren. Kann man denn nicht die Leerstellen zählen? Oder ev. in ein json wandeln - das wäre für die Auswertung weiterer Datenpunkte ggf. sinnvoller. Leider kenn ich mich da auch nicht besonders aus.

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

                      Dann muss man einen anderen String als Anker nehmen; wird dann halt etwas unübersichtlicher.

                      Auch hier wäre die Voraussetzung, dass die Formatierung der Werte immer gleich bleibt (ein oder mehrstellig vor dem Punkt kann man kompensieren)

                      Gruß

                      Rainer

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

                        \d*\/\d*\/\d*( \S*\.\d){38}
                        

                        @starfish:

                        Leider kenn ich mich da auch nicht besonders aus. `
                        bei mir auch nur try and error.

                        Deswegen wollte ich ja den Wert haben.

                        Gruß

                        Rainer

                        1 Reply Last reply Reply Quote 0
                        • D
                          der_broker last edited by

                          Hallo,

                          ich habe noch ein kleines Problem beim Parsen von

                          ![](http://chart.googleapis.com/chart?chs=280x160&chd=t:0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,14,35,59,86,113,132,164,244,351,406,393,568,533,540,561,578,1035,1071,1467,2251,3555,2612,2784,4045,3825,2188,2216,4030,4370,4791,4802,4056,3703,4015,3646,3626,2648,2083,1868,2166,1572,1393,1298,1220,1300,1553,1996,2304,1569,1731,2007,2207,2442,2245,2759,2277,1870,1405,1164,1264,1396,1519,1970,1695,1599,1057,978,924,827,719,675,524,553,636,453,249,314,294,232,253,257,238,235,249,210,145,100,83,72,45,26,5,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0&cht=lc&chds=0,9100&chxr=0,7,18,2|1,0,9100&chtt=06.01.2018+16:15:05&chdlp=bv&chm=B,FF0000,0,0,0&chco=FF0000)
                          
                          Den Monat bekomme ich mit - Hier muss der Monat allerdings mindestens 2-stellig sein  ;)
                          

                          \d{0,1}\d\d{1,2}(?=<)

                          der Tag funktioniert korrekt mit
                          

                          \d{1,2}.\d\d{0,1}(?=<)

                          
                          Nun würde ich gerne noch PAC parsen.
                          
                          Das geht doch sicherlich über das Wort "PAC"
                          
                          Daran scheitere ich aber :(
                          
                          Habe ihr eine Tipp für mich?
                          
                          Die Regex Seite ist schon eine grosse Hilfe.
                          
                          Wenn ich jetzt noch einen Wert auswählen könnte und die Regex Seite schlägt mir den Code vor –  :lol:
                          
                          | Tag: | 10.9 | kWh | Monat: | 33 | kWh |
                          | Jahr: | 33 | kWh | Gesamt: | 50597 | kWh |
                          | PAC: | 0 | W | 
                          
                          
                          1 Reply Last reply Reply Quote 0
                          • Homoran
                            Homoran Global Moderator Administrators last edited by

                            @der_broker:

                            Wenn ich jetzt noch einen Wert auswählen könnte und die Regex Seite schlägt mir den Code vor – `
                            Das habe ich mir auch schon oft gewünscht 8-)

                            @der_broker:

                            Das geht doch sicherlich über das Wort "PAC"

                            Daran scheitere ich aber `
                            Ich bin da immer brutal, auch wenn es wahrscheinlich immer deutlich eleganter gehen würde.

                            Die Folge von PAC bis zum Wert von pac sieht ziemlich eindeutig aus, einfach als regex nehmen.

                            Bin nicht am PC und am Handy macht das kei en Spaß

                            Gruß Rainer

                            1 Reply Last reply Reply Quote 0
                            • D
                              der_broker last edited by

                              Hallo Rainer, daran bastle ich gerade 🙂

                              Ich dachte nur es geht eleganter.

                              Markiert bekomme ich den Bereich, nun muss ich noch den Wert danach filtern.

                              1 Reply Last reply Reply Quote 0
                              • S
                                starfish last edited by

                                hallo Rainer,

                                @Homoran:

                                \d*\/\d*\/\d*( \S*\.\d){38}
                                

                                gute Idee, der Bezugspunkt mit den 2 "/" im Datum ist immer vorhanden. Den kann ich definitiv nehmen. Anschliessend zählst Du ja die "." bis zur richtigen Stelle. Möglicherweise sind aber nicht immer alle "." vorhanden, deshalb suche ich eine Möglichkeit die Leerstellen/Spaces zu zählen. Regex sieht hier \s vor. Funktioniert aber nicht hier. hast Du eine Idee - wie muss ich den whitespace einbauen?

                                (betrifft: http://forum.iobroker.net/viewtopic.php … 61#p109717 )

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

                                  Meines wissens ist ein bloßes zählen von whitespaces per regex nicht möglich.

                                  Wenn ich mal wieder am revhner sitze versuche ich es mal mit \S*\s , also beliebige anzahl non-whitespace, gefolgt von einem whitespace

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

                                    @der_broker:

                                    noch den Wert danach filtern. `
                                    Klammern drum?

                                    1 Reply Last reply Reply Quote 0
                                    • D
                                      der_broker last edited by

                                      Schwere Geburt 😄

                                      \d{0,5}(?=</td>W</td></body></html>) funktioniert bei PAC

                                      Ich habe halt von hinten angefangen, nicht bei PAC

                                      1 Reply Last reply Reply Quote 0
                                      • B
                                        Buhu91 last edited by

                                        Hey,

                                        ich hoffe ich bin im richtigen Thread gelandet, zumindest brachte mich die suche immer wieder auf Parser.

                                        Ich würde mir gerne einen Abfahrtsmonitor für die nächstgelegene Haltestelle für VIS bauen.

                                        Hierfür bietet die VAG auch eine API an.

                                        https://start.vag.de/dm/

                                        Nun wollte ich wissen, ob ich den erzeugten Link mit der Haltestellen ID einfach in Parser eintragen kann, und was er mir dann ausspuckt.

                                        Und ob Parser überhaupt der Richtige Adapter bzw Methode dafür ist.

                                        Entschuldigt wenn mir das nötige Fachwissen fehlt, ich bin immoment dabei mich so gut wie möglich in den IOBroker

                                        einzuarbeiten und zu verstehen. :oops:

                                        1 Reply Last reply Reply Quote 0
                                        • G
                                          Gürol last edited by

                                          @Buhu91:

                                          ich hoffe ich bin im richtigen Thread gelandet, zumindest brachte mich die suche immer wieder auf Parser.

                                          Ich würde mir gerne einen Abfahrtsmonitor für die nächstgelegene Haltestelle für VIS bauen.

                                          Hierfür bietet die VAG auch eine API an.

                                          https://start.vag.de/dm/

                                          Nun wollte ich wissen, ob ich den erzeugten Link mit der Haltestellen ID einfach in Parser eintragen kann, und was er mir dann ausspuckt.

                                          Und ob Parser überhaupt der Richtige Adapter bzw Methode dafür ist. `
                                          Hallo Buhu91,

                                          herzlich Willkommen bei IObroker.

                                          Ja, für den Abfahrtsmonitor bist du hier richtig.

                                          Du kannst den Link in den Parser eintragen und er würde dir ungefiltert (also "ungeparst") die ganze Antwortseite von VAG als HTML-Text ausspucken.

                                          Du müsstest jetzt noch ran gehen und aus diesem HTML-Code dir das ausfiltern (also parsen), was du tatsächlich anzeigen willst.

                                          Ein solcher Filter wird mit einem regulären Ausdruck aufgebaut.

                                          Du kannst die Filterung auf der Webseite "regex101.com" ausprobieren, bevor du sie im IObroker einbaust.

                                          Gruß

                                          Gürol

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

                                            Guten Morgen,

                                            auch ich habe Probelem mit dem Parsen.

                                            Und zwar habe ich ein CGI File aus einer Solar-Anlage von TA.

                                            Das CGI File kann man schön im Browser ansehen.

                                            Hier die Datei````

                                            10:18:09

                                            09.01.2018

                                            S1 - Kollektor-Temperatur

                                            S2 - Wasserspeicher-Temperatur

                                            3,5°C

                                            40,2°C

                                            0

                                            37W/m²

                                            8,4°C

                                            0l/h

                                            AUS

                                            AUS

                                            S3 - nichts angeschlossen

                                            S4 - Sonneneinstrahlung

                                            S5 - ZisternenTemperatur

                                            S6 Volumenstrom

                                            Ext1 Volumenstrom Speicher Eingang

                                            Ext2 Temperatur Speicher Eingang

                                            0

                                            0l/h

                                            19,9°C

                                            0

                                            0,0

                                            0V

                                            0,0

                                            0MWh

                                            319,3kW

                                            0

                                            2kWh

                                            
                                            Unter RegEx101 zeigt er Fehler an.
                                            
                                            Was müsste ich im Parser-Adapter und RegEx eintragen um die einzelnen Werte, oder als Beispiel am Anfang die Uhrzeit als Datenpunkt eingetragen zu bekommen?
                                            
                                            Danke und Grüße
                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            645
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            43
                                            268
                                            100032
                                            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