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.
    • F
      fruehwi last edited by

      Hallo Pix,

      Wenn man die /g am Ende weg lässt funktioniert es.

      Vielen Danke!

      Viele Grüße,

      Fruehwi

      1 Reply Last reply Reply Quote 0
      • BBTown
        BBTown last edited by

        @BBTown:

        Was mir allerdings aufgefallen ist: Der Adapter ist ein echter Speicherfresser! `
        hmmm … was auch immer sich geändert haben mag, ich kann den Vorwurf des Speicherfressens nicht weiter aufrecht halten.

        Bei mir hat sich der Speicherbedarf nun um die 30 - 32 MB eingependelt.
        1917_parser_speicherbedarf.jpg

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

          Hallo zusammen,

          besteht beim parser auch die Möglichkeit eine Website bei der credentials zum einloggen notwendig sind auszulesen?

          bei mir geht es um das Webinterface meines Wechselrichters.

          Teile laufen davon noch über bash-script mit einem wget-Aufruf:

          wget $COMMONWGETARGS --http-user=UserName --http-password=PassWort "http://192.168.xxx.yyy/index.fhtml" | sed -e "s/nbsp/nbsp;/g" | sed -e "s/nbsp;;/nbsp;/g" | sed -e "s/\ //g" | html2text | tr -s " \t\r\n" | sed -e "s/^ //" | sed -e "s/x x x/0/g" >/tmp/power-inverter1.values
          

          Keine Angst, das habe ich nicht ersonnen, sondern "ausgeliehen".

          Gruß

          Rainer

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

            Habe es mittlerweile anscheinend hinbekommen, zumindest lief es auf einmal mit http://UserName:PassWort@IP.

            Dann hatte ich sogar das regex (teilweise) mit viel try and noch mehr Error hinbekommen.
            144_helios_status.jpg
            Dabei kam dann nur "Einspeisen" heraus. Das war mir erst einmal egal, bis mir der Gedanke kam, dass ja wer weiß was für Meldungen kommen könnten, die ggf. auch aus noch mehr Worten bestehen könnten. Also habe ich den Regex geändert. Seit dem kommt gar nichts mehr so richtig.

            Im Objekt steht immer nur null
            144_helios_status_02.jpg

            Ob das jetzt am RegEx liegt oder wo anders dran weiß ich nicht wirklich. Auch der Versuch das ursprüngliche RegEx zu nehmen führt jetzt zu dem Fehler. Der Timestamp ändert sich auch bei einem Restart nicht mehr.

            Und so sieht es in der Adapterkonfig aus:
            144_helios_status_03.jpg

            Hülfää büdde!

            Gruß

            Rainer

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

              Auch das habe ich jetzt hinbekommen, ich musste noch das \n aus dem RegEx nehmen (fiel mir beim x-ten drübersehen auf, dass das zu Anfang auch nicht drin war)

              Gruß

              Rainer

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

                Leider muss ich mich nochmal melden.

                Mit der ganzen Aktion wollte ich den Status meines Wechselrichters loggen, weil es anscheinend zu Störungen kam. Dies war heute morgen wieder der Fall, da stand dann in dem Datenpunkt nur "St" :shock:

                In der WebUI stand dann wo hier Einspeisen MPP steht Störung Isolationsfehler.
                144_wr_webui.jpg
                Dies wollte ich loggen.
                144_parser_wr_states.jpg
                Aber auch dort steht nur "St" und sonst nichts.

                Ich nehme an, dass der Umlaut ö das Problem erzeugt.

                Leider habe ich von dem Zeitpunkt keinen Seitenquelltext, sondern nur von gerade eben:

                ! ````
                ! <title>PV Webserver</title>
                ! <form method="post" action="">
                ! | |
                ! | |

                PIKO 5.5

                ! Helios (255)
                |
                |
                ! |

                ! * * *
                ! |
                ! | |
                ! |

                AC-Leistung |
                  |

                Energie |

                ! | |
                ! |

                aktuell |

                1278 |
                  W |

                Gesamtenergie |

                27319 |
                  kWh |
                  |

                ! | |
                ! |

                |

                |
                  |

                Tagesenergie |

                13.98 |
                  kWh |
                  |

                ! | |
                ! |

                Status |

                Einspeisen MPP |
                  |

                ! | |
                ! |
                ! |

                ! * * *
                ! |
                ! | |
                ! |
                ! |

                PV-Generator |
                  |

                Ausgangsleistung |
                  |
                  |

                ! | |
                ! |

                <u>String 1</u> |
                  |
                  |

                <u>L1</u> |
                  |
                  |
                  |

                ! |

                Spannung |

                324 |
                  V |

                Spannung |

                230 |
                  V |
                  |

                ! | |
                !   |

                Strom |

                1.97 |
                  A |

                Leistung |

                428 |
                  W |
                  |

                ! | |
                ! |

                <u>String 2</u> |
                  |
                  |

                <u>L2</u> |
                  |
                  |
                  |

                ! |

                Spannung |

                347 |
                  V |

                Spannung |

                230 |
                  V |
                  |

                ! | |
                !   |

                Strom |

                2.14 |
                  A |

                Leistung |

                427 |
                  W |
                  |

                ! | |
                ! |

                <u>String 3</u> |
                  |
                  |

                <u>L3</u> |
                  |
                  |
                  |

                ! |

                Spannung |

                0 |

                V |

                Spannung |

                224 |
                  V |
                  |

                ! | |
                !   |

                Strom |

                0.00 |

                A |

                Leistung |

                423 |
                  W |
                  |

                ! | |
                ! |
                ! | |

                ! * * *
                ! |
                ! | |
                ! |
                ! | |
                RS485 Kommunikation |
                ! | |
                ! | |
                Wechselrichter |
                | |
                ! * * *
                ! | |
                ! | |

                Historie

                Infoseite |

                Einstellungen

                ! </form>
                ! ````

                im Parser Adapter lese ich den Status aus mit

                ((?:\s+\w+)+)
                

                Das klappte mit den Standard zuständen beim online regex-tester problemlos.

                EDIT: Habe gerade bei regex101.com manuell "Einspeiden MPP" gegen "Störung Isolationsfehler" ausgetauscht, da ergibt der RegEx auch nur "St"

                Kann mir da bitte noch einmal jemand unter die Arme greifen?

                EDIT2: Nach einigem googeln klappt es jetzt hoffentlich mit

                (?:\s+([a-zA-Z äöüÄÖÜ]+))
                

                Gruß

                Rainer

                1 Reply Last reply Reply Quote 0
                • P
                  pix last edited by

                  Hallo Rainer,

                  sieht doch gut aus. Nimm das

                  ß
                  ````auch gleich noch mit rein.
                  
                  Gibt es kein Doku vom Piko 5.5, welche alle Stati auflistet? Dann kannst du darauf gezielt Alarme triggern.
                  
                  Gruß,
                  
                  Pix
                  1 Reply Last reply Reply Quote 0
                  • Homoran
                    Homoran Global Moderator Administrators last edited by

                    Hallo pix,

                    beides gute Ideen!

                    das ß werde ich noch mit reinnehmen und wegen der Fehlermeldungen werde ich den Solarteur fragen, der am Montag kommt.

                    Gruß

                    Rainer

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

                      Hallo zusammen,

                      ich hoffe, die Frage ist nicht zu trivial. Ich parse ebenfalls die Seite meiner Stiebel-Eltron-Wärmepumpe aber komme bei einem Wert nicht weiter.

                      Ich frage mit dieser Zeile die Webseite ab:

                      SOLLTEMPERATUR.*\n.+>(\d+,\d+)
                      

                      Das Problem: Im Quelltext gibt es folgende Variablen in dieser Reihenfolge. Zuerst:

                      
                          SOLLTEMPERATUR HK 1
                          22,2 °C
                      
                      

                      Und dann:

                      
                          SOLLTEMPERATUR
                          40,0 °C
                      

                      Ich möchte eigentlich die SOLLTEMPERATUR ausgegeben bekommen, bekomme aber immer den Wert SOLLTEMPERATUR HK 1 angezeigt. Hat jemand eine Idee, wie ich nur das Feld SOLLTEMPERATUR auslese und er ähnliche Treffer, die am Ende aber anders heißen, ignoriert?

                      Danke und viele Grüße

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

                        Poste mal den ganzen Quelltext.

                        Hast du dir schon mal http://www.regex101.com angesehen?

                        Gruß

                        Rainer

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

                          @Homoran:

                          Poste mal den ganzen Quelltext. `

                          
                          	<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)
                          
                          *   [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)
                          
                                  ANLAGE
                          
                          <form id="werte" action="#" onsubmit="saveValues(this);return false;">
                          
                          | HEIZUNG |  
                          
                               AUSSENTEMPERATUR |
                               12,0 °C |
                          
                               ISTTEMPERATUR HK 1 |
                               23,1 °C |
                          
                               SOLLTEMPERATUR HK 1 |
                               21,0 °C |
                          
                               RÜCKLAUFISTTEMPERATUR |
                               23,1 °C |
                          
                               ANLAGENFROST |
                               4,0 °C |
                          
                          | WARMWASSER |  
                          
                               ISTTEMPERATUR |
                               38,3 °C |
                          
                               SOLLTEMPERATUR |
                               30,5 °C |
                          
                                </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.5.6
                          
                            		© STIEBEL ELTRON 2016
                          
                          

                          > Hast du dir schon mal [http://www.regex101.com](http://www.regex101.com) angesehen?
                          Ja, da bekomme ich das folgende Ergebnis:
                          1129_regex.jpg

                          Hm, hast du eine Idee?

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

                            @Kunibert:

                            Hm, hast du eine Idee? `
                            Darf es auch eine lösung sein 😉

                            Nimm das als Regex

                            SOLLTEMPERATUR<\/td>\n\s+(\d+,\d)
                            

                            Gruß

                            Rainer

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

                              Tausend Dank Rainer, funktioniert!!

                              🙂

                              LG und einen schönen Abend

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

                                @Kunibert:

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

                                Gruß

                                Rainer

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

                                  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 Reply Quote 0
                                  • G
                                    Gürol last edited by

                                    @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 Reply Quote 0
                                    • K
                                      Kunibert last edited by

                                      Funktioniert, Danke! Ich glaub jetzt ist es klar…

                                      1 Reply Last reply Reply Quote 0
                                      • T
                                        tim73 last edited by

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

                                          @tim73:

                                          Hat jemand vielleicht eine Idee ? `

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

                                          Gruß

                                          Rainer

                                          1 Reply Last reply Reply Quote 0
                                          • T
                                            tim73 last edited by

                                            werde ich testen

                                            danke

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            795
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

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