NEWS
Adapter - Parser (regEx)
-
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.
Dies wollte ich loggen.
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 |
| |
! * * *
! | |
! | |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
-
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
-
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
-
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
-
Poste mal den ganzen Quelltext.
Hast du dir schon mal http://www.regex101.com angesehen?
Gruß
Rainer
-
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:
Hm, hast du eine Idee?
-
Hm, hast du eine Idee? `
Darf es auch eine lösung seinNimm das als Regex
SOLLTEMPERATUR<\/td>\n\s+(\d+,\d)
Gruß
Rainer
-
Tausend Dank Rainer, funktioniert!!
LG und einen schönen Abend
-
Tausend Dank Rainer, funktioniert!! `
Schön, dann kann ich den Regex101.com ja wieder schließenGruß
Rainer
-
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
-
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
-
Funktioniert, Danke! Ich glaub jetzt ist es klar…
-
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
-
-
werde ich testen
danke
-
-
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
-
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
-
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?
-
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