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.
    • 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
                                          • Homoran
                                            Homoran Global Moderator Administrators last edited by

                                            @hg6806:

                                            Woher hast du den nachfolgenden Ausdruck "\n(\d*:\d*:\d*)"? `
                                            Diese Befehle sind die regEx gemäß der Erklärungen unten rechts bzw in den rechts oben erscheinenden "Explanations". Dort werden die Befehle alle noch einmal einzeln erklärt, wie sie funktionieren und welches Ergebnis sie zur Folge haben.

                                            @hg6806:

                                            Jetzt dachte ich ok, nehme einfach für den zweiten Ausdruck 2" >….. `
                                            der zweite Ausdruck enzhält aber keine Uhrzeit in dem Format dd:dd:dd sondern das Datum in dem Format dd.dd.dddd

                                            das wäre dann aus dem Kopf (ungetestet) \n(\d*.\d*.\d*)

                                            Gruß

                                            Rainer

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            651
                                            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