Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Tester
  4. Adapter - Parser (regEx)

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    22
    1
    1.1k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.2k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    14
    1
    2.4k

Adapter - Parser (regEx)

Scheduled Pinned Locked Moved Tester
268 Posts 43 Posters 137.8k Views 9 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • HomoranH Do not disturb
    HomoranH Do not disturb
    Homoran
    Global Moderator Administrators
    wrote on last edited by
    #77

    @Kunibert:

    Tausend Dank Rainer, funktioniert!! `
    Schön, dann kann ich den Regex101.com ja wieder schließen ;-)

    Gruß

    Rainer

    kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

    der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

    1 Reply Last reply
    0
    • K Offline
      K Offline
      Kunibert
      wrote on last edited by
      #78

      Rainer, kann ich dir noch eine Frage dazu stellen. Ich habe mir den Aufbau jetzt nochmal angeschaut aber komme nicht dahinter, was du nun anders gemacht hast. Bei SOLLTEMPERATUR funktioniert es ja nun auch, bei ISTTEMPERATUR habe ich aber einen ähnlichen Fall. Nur gibt es hier einen anderen Wert der gefunden wird, der RÜCKLAUFISTTEMPERATUR im Namen stehen hat und deshalb bekomme ich wieder einen doppelten Eintrag.

      Wie kann ich dann mit dem Ausdruck einfach sicherstellen, dass immer nur 1:1 das gesuchte Wort eindeutig gefunden wird und nicht auch Ausdrücke, die im Namen davon oder dahinter noch etwas stehen haben?

      Und könntest du mir für die ISTTEMPERATUR auch noch einmal den Ausdruck schicken?

      Danke und viele liebe Grüße

      1 Reply Last reply
      0
      • G Offline
        G Offline
        Gürol
        wrote on last edited by
        #79

        @Kunibert:

        Rainer, kann ich dir noch eine Frage dazu stellen. (…)

        Und könntest du mir für die ISTTEMPERATUR auch noch einmal den Ausdruck schicken? `
        Hallo Kunibert,

        ich heiße zwar nicht Rainer, aber ich antworte trotzdem mal. ;-)

        Was Rainer gemacht hat, war eigentlich recht einfach.

        Er hat (statt nach "SOLLTEMPERATUR") nach "SOLLTEMPERATUR" gesucht.

        Da "SOLLTEMPERATUR" in "SOLLTEMPERATUR HK 1" nicht vorkommt, gab es nur einen Treffer.

        Die Lösung für dein nächstes Problem läßt sich (fast automatisch) davon ableiten.

        Du mußt lediglich (statt nach "ISTTEMPERATUR") nach ">ISTTEMPERATUR" suchen.

        Ausdruck dafür lautet:

        >ISTTEMPERATUR<\/td>\n\s+(\d+,\d)
        ````Gruß
        
        Gürol
        1 Reply Last reply
        0
        • K Offline
          K Offline
          Kunibert
          wrote on last edited by
          #80

          Funktioniert, Danke! Ich glaub jetzt ist es klar…

          1 Reply Last reply
          0
          • T Offline
            T Offline
            tim73
            wrote on last edited by
            #81

            Hallo Zusammen.

            Ich benötige einmal bitte eure Hilfe - ich glaub ich steh gerade auf den Schlauch

            Für folgenden Text benötige ich die Regex

            {"channel":{"id":332800,"name":"Gewächshaus","latitude":"0.0","longitude":"0.0","field1":"temperature",
            "field2":"humidity","created_at":"2017-09-17T15:40:24Z","updated_at":"2017-09-18T18:29:42Z","last_entry_id":374},
            "feeds":[{"created_at":"2017-09-18T18:29:42Z","entry_id":374,"field1":"21.2000007629"}]}
            
            

            Ich hätte gerne die Temperatur 21.20000…..

            Leider ändert sich die entry_id":374 bei jeden Aufruf.

            Hat jemand vielleicht eine Idee ?

            Danke schon mal

            Tim

            1 Reply Last reply
            0
            • HomoranH Do not disturb
              HomoranH Do not disturb
              Homoran
              Global Moderator Administrators
              wrote on last edited by
              #82

              @tim73:

              Hat jemand vielleicht eine Idee ? `

              "field1":"(\d+.\d+)
              

              Gruß

              Rainer

              kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

              Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

              der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

              1 Reply Last reply
              0
              • T Offline
                T Offline
                tim73
                wrote on last edited by
                #83

                werde ich testen

                danke

                1 Reply Last reply
                0
                • BluefoxB Offline
                  BluefoxB Offline
                  Bluefox
                  wrote on last edited by
                  #84

                  @Homoran:

                  @tim73:

                  Hat jemand vielleicht eine Idee ? `

                  "field1":"(\d+.\d+)
                  

                  Gruß

                  Rainer `
                  Schon richtig, aber ich würde es so erweitern:

                  "field1":"(\d+.?\d*)"
                  

                  Damit auch "21" erkannt werden kann.

                  1 Reply Last reply
                  0
                  • K Offline
                    K Offline
                    Kunibert
                    wrote on last edited by
                    #85

                    @Gürol:

                    @Kunibert:

                    Rainer, kann ich dir noch eine Frage dazu stellen. (…)

                    Und könntest du mir für die ISTTEMPERATUR auch noch einmal den Ausdruck schicken? `
                    Hallo Kunibert,

                    ich heiße zwar nicht Rainer, aber ich antworte trotzdem mal. ;-)

                    Was Rainer gemacht hat, war eigentlich recht einfach.

                    Er hat (statt nach "SOLLTEMPERATUR") nach "SOLLTEMPERATUR" gesucht.

                    Da "SOLLTEMPERATUR" in "SOLLTEMPERATUR HK 1" nicht vorkommt, gab es nur einen Treffer.

                    Die Lösung für dein nächstes Problem läßt sich (fast automatisch) davon ableiten.

                    Du mußt lediglich (statt nach "ISTTEMPERATUR") nach ">ISTTEMPERATUR" suchen.

                    Ausdruck dafür lautet:

                    >ISTTEMPERATUR<\/td>\n\s+(\d+,\d)
                    ````Gruß
                    
                    Gürol `  
                    

                    Vielleicht kann ich euch noch eine Frage dazu stellen, das bekomme ich nicht hin:

                    Aus diesem Quelltext möchte ich etwas extrahieren:

                    
                    	<title>STIEBEL ELTRON Reglersteuerung</title>
                    
                        **[DEUTSCH](?s=5,3)**
                    
                          [![Servicewelt](./pics/title.png)](. "zur Startseite") 
                    
                    		[ ](. "zur Startseite")
                    
                              [START](?s=0)
                    
                              <a>INFO</a>
                    
                    *   [ANLAGE](?s=1,0)
                    
                    *   [WÄRMEPUMPE](?s=1,1)
                    
                    *   [LIZENZBESTIMMUNGEN](?s=1,2)
                    
                    *   [BEDIENUNG UND INSTALLATION](?s=1,3)
                    
                              <a>DIAGNOSE</a>
                    
                    *   [ANLAGE](?s=2,0)
                    
                    *   [SYSTEM](?s=2,2)
                    
                    *   [EREIGNISLISTE](?s=2,4)
                    
                              <a>PROGRAMME</a>
                    
                    *   [HEIZPROGRAMM](?s=3,0)
                    
                    *   [WARMWASSERPROGRAMM](?s=3,1)
                    
                    *   [SILENTPROGRAMM](?s=3,2)
                    
                    *   [PARTYPROGRAMM](?s=3,3)
                    
                    *   [FERIENPROGRAMM](?s=3,4)
                    
                              <a>EINSTELLUNGEN</a>
                    
                    *   [HEIZEN](?s=4,0)
                    
                    *   [WARMWASSER](?s=4,1)
                    
                    *   [ENERGIEMANAGEMENT](?s=4,4)
                    
                    *   [ZEIT/DATUM](?s=4,5)
                    
                    *   [RESET](?s=4,6)
                    
                              <a>PROFIL</a>
                    
                    *   [Netzwerk](?s=5,0)
                    
                    *   [Sicherheit](?s=5,1)
                    
                    *   [Anlagenbild](?s=5,2)
                    
                    *   [SPRACHE](?s=5,3)
                    
                            WÄRMEPUMPE
                    
                    <form id="werte" action="#" onsubmit="saveValues(this);return false;">
                    
                    | WÄRMEMENGE |  
                    
                         VD HEIZEN TAG |
                         0,000 kWh |
                    
                         VD HEIZEN SUMME |
                         7,569 MWh |
                    
                         VD WARMWASSER TAG |
                         15,437 kWh |
                    
                         VD WARMWASSER SUMME |
                         7,271 MWh |
                    
                         NHZ HEIZEN SUMME |
                         0,000 MWh |
                    
                         NHZ WARMWASSER SUMME |
                         0,000 MWh |
                    
                    | LEISTUNGSAUFNAHME |  
                    
                         VD HEIZEN TAG |
                         0,000 kWh |
                    
                         VD HEIZEN SUMME |
                         2,082 MWh |
                    
                         VD WARMWASSER TAG |
                         3,968 kWh |
                    
                         VD WARMWASSER SUMME |
                         2,112 MWh |
                    
                    | LAUFZEIT |  
                    
                         VD HEIZEN |
                         1153 h |
                    
                         VD WARMWASSER |
                         888 h |
                    
                         VD ABTAUEN |
                         41 h |
                    
                         NHZ 1 |
                         60 h |
                    
                         NHZ 2 |
                         28 h |
                    
                         NHZ 1/2 |
                         65 h |
                    
                         ZEIT ABTAUEN |
                         1 min |
                    
                         STARTS ABTAUEN |
                         1129  |
                    
                    | STARTS |  
                    
                         VERDICHTER |
                         2714  |
                    
                          </form>
                    
                    				![](./pics/ste_footer_website.png)
                    
                              					Weitere Informationen zu unserem Produktprogramm und aktuelle Serviceangebote finden Sie unter					[www.stiebel-eltron.de](http://www.stiebel-eltron.de)
                    
                    			  ![](./pics/footer_tel.png)
                    
                    					Unsere Service-Hotline erreichen Sie unter
                    05531 702 90015
                    
                    				Das Neueste rund um die Servicewelt				
                    [servicewelt](http://www.stiebel-eltron.de/erneuerbare-energien/kundenservice/servicewelt/isg/)
                    
                            		[Datenschutz](?s=1,2&arch=datenschutzerklaerung)
                    
                    v8.6.0
                    
                      		© STIEBEL ELTRON 2017
                    
                    

                    Es gibt dort zweimal den Wert VD HEIZEN TAG, einmal in der Klasse WÄRMEMENGE und einmal in der Klasse LEISTUNGSAUSNAHME (an zweiter Stelle).

                    Ich würde nun gerne den Wert von VD HEIZEN TAG aus der Klasse LEISTUNGSAUSNAHME auslesen.

                    Hiermit komme ich jedoch nicht weiter, in Regex bekomme ich zwei Ergebnisse angezeigt:

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

                    Ich habe nun versucht, vor die Abfrage wie folgt zu ändern aber bekomme nichts hin, was mir Regex nicht als Fehler anzeigt:

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

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

                    Liebe Grüße

                    David

                    1 Reply Last reply
                    0
                    • G Offline
                      G Offline
                      Gürol
                      wrote on last edited by
                      #86

                      @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
                      0
                      • K Offline
                        K Offline
                        Kunibert
                        wrote on last edited by
                        #87

                        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
                        0
                        • HomoranH Do not disturb
                          HomoranH Do not disturb
                          Homoran
                          Global Moderator Administrators
                          wrote on last edited by
                          #88

                          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

                          kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                          Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                          der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                          1 Reply Last reply
                          0
                          • S Offline
                            S Offline
                            starfish
                            wrote on last edited by
                            #89

                            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
                            0
                            • HomoranH Do not disturb
                              HomoranH Do not disturb
                              Homoran
                              Global Moderator Administrators
                              wrote on last edited by
                              #90

                              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

                              kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                              Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                              der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                              1 Reply Last reply
                              0
                              • S Offline
                                S Offline
                                starfish
                                wrote on last edited by
                                #91

                                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
                                0
                                • HomoranH Do not disturb
                                  HomoranH Do not disturb
                                  Homoran
                                  Global Moderator Administrators
                                  wrote on last edited by
                                  #92

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

                                  (\d*\.\d)\s\d*\.\d\s\d ---
                                  

                                  kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                                  Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                  der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                                  1 Reply Last reply
                                  0
                                  • S Offline
                                    S Offline
                                    starfish
                                    wrote on last edited by
                                    #93

                                    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
                                    0
                                    • HomoranH Do not disturb
                                      HomoranH Do not disturb
                                      Homoran
                                      Global Moderator Administrators
                                      wrote on last edited by
                                      #94

                                      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

                                      kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                                      Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                      der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                                      1 Reply Last reply
                                      0
                                      • HomoranH Do not disturb
                                        HomoranH Do not disturb
                                        Homoran
                                        Global Moderator Administrators
                                        wrote on last edited by
                                        #95
                                        \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

                                        kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                                        Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                        der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                                        1 Reply Last reply
                                        0
                                        • D Offline
                                          D Offline
                                          der_broker
                                          wrote on last edited by
                                          #96

                                          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 | 
                                          
                                          

                                          IOBroker auf Cubietruck / Homematic auf yahm

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          673

                                          Online

                                          32.5k

                                          Users

                                          81.6k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe