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.
    • 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
                                • B
                                  Buhu91 last edited by

                                  @Gürol:

                                  @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 `

                                  Danke dir! Ich versuch mich mal dran wenn ich mal länger als ne Stunde drüber bleiben kann, immerhin weiß ich schon mal das ich richtig bin 🙂

                                  Gruß

                                  Buhu

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

                                    Moin!

                                    nochmal die Frage wie ich die angehängte Datei parsen kann, bzw. bei RegEx eintrage, da RegEx101 einen Fehler ausspuckt.
                                    1752_1.txt

                                    Danke!

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

                                      @hg6806:

                                      Unter RegEx101 zeigt er Fehler an. `
                                      Was für fehler denn?

                                      Bei welchem Regex?

                                      Mangels Infos:

                                      Hast du den Editor auf JavaScript gestellt?

                                      Gruß Rainer

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

                                        Anbei ein Screenshot von RegEx101

                                        1752_2018-01-11_22_04_52-online_regex_tester_and_debugger__php__pcre__python__golang_and_javascript.jpg

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

                                          Bin jetzt nicht zu Hause am Rechner.

                                          Habe dort gestern extra für dich einen Screenshot eines funktionierenden RegEx geschossen.

                                          Mal sehen ob ich es hier hin bekomme.

                                          Gruß

                                          Rainer

                                          EDIT:
                                          144_regex.jpg
                                          Was willst du eigentlich mit deinem RegEx genau erreichen?

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

                                            OK, die erste Zeile zumindest hat funktioniert, auch im Parser-Adapter

                                            Woher hast du den nachfolgenden Ausdruck "\n(\d*:\d*:\d*)"?

                                            Jetzt dachte ich ok, nehme einfach für den zweiten Ausdruck 2" >…..

                                            Geht aber nicht.

                                            Wie kann ich die weiteren Werte extrahieren?

                                            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