NEWS
Adapter - Parser (regEx)
-
Das liegt vielleicht daran, dass du hier im Tester Forum bist.
Stell die Frage doch bitte im Skripting Forum.
Gruß
Rainer
-
Hi Leute,
ich habe heute ebenfalls den Parser Adapter installiert und möchte damit das Internet Service Gateway(ISG) meiner Stiebel Eltron Wärmepumpe auslesen.
Ich finde leider keine Anleitung zu dem Parser Adapter.
Könnt ihr mir in die richtige Richtung helfen ?
Ich möchte z.B. folgende URL auslesen: http://192.168.222.20/?s=1,1
Die Seite sieht so aus:
Wenn ich beim Browser auf untersuchen gehe kommt folgendes:
und meine parser Einstellungen schauen so aus:
Was muss ich bei RegEx eintragen um die verschiedenen Werte ausgelesen zu bekommen ?
Muss ich für jeden Wert und für jedes Wort eine eigene Regel erstellen ?
-
Mit````
\d{0,3},\d{0,3}(?= bar)bekomme ich z.B. den korrekten Wert für HOCHDRUCK geliefert, aber auch nur den. Wie kann ich dann den Wert für NIEDERDRUCK auslesen, der ebenfalls mit bar als Einheit gelistet ist ? Muss ich also für jeden Wert den ich auslesen möchte, eine eigene Regel erstellen, oder gibt es einen anderen Weg als 30 Regeln pro Seite zu erstellen ?
-
Willst du den für jeden Wert einen ydatenpunkt jaben, z.B. um mit diesen Werten weiterzuarbeiten, oder z.B. als gauge darzustellen?
Gruß
Rainer
-
Ich möchte alle Werte primär darstellen, aber auch mit flot Langzeitdiagramme erstellen.
Weiterverarbeiten ist nur bei einigen wenigen Werten notwendig.
Macht das einen Unterschied ?
-
Auch loggen und darstellen ist ein weiterverarbeiten
Dann benötigst du auch einzelne Datenpunkte, und somit einzelne Regeln.
Müssen ja nur einmal erstellt werden.
Gruß
Rainer
-
Und wie kann ich z.B. Hochdruck und Niederdruck auslesen, bzw. allgemein Werte die dieselbe Einheit haben und auf derselben URL stehen ?
Wenn ich \d{0,3},\d{0,3}(?= bar) bei der ersten Regel eingebe krieg ich automatisch den Wert für Hochdruck, wie müsste dann die Regel für den Niederdruckwert aussehen ?
-
-
Kannst Du den Quellcode der Webseite hier posten. Dann kann man Dir besser helfen
-
Hallo,
die Werte werden ja hübsch aufgelistet. Eigentlich musst du für jeden Wert eine neue Abfrage im Regexp Adapter machen.
Ein Skript im Javascript Adapter sollte das auch können. Hab gerade keine Zeit, aber für ein ähnliches Projekt nutze ich den Node htmlparser.
var htmlparser = require("htmlparser");
https://www.npmjs.com/package/htmlparser
Damit kann man dann die von HTML in JSON konvertierte Datei schön durcharbeiten.
Das macht vor allem dann Sinn, wenn die Ausgabe der Werte auf der HTML-Seite nicht immer in der gleichen Reihenfolge stattfindet.
Gruß
Pix
-
Kannst Du den Quellcode der Webseite hier posten. Dann kann man Dir besser helfen `
! ````
! <title>STIEBEL ELTRON Reglersteuerung</title>!
!
!
!
**[DEUTSCH](?s=5,3)** [![Servicewelt](./pics/title.png)](. "zur Startseite") [ ](. "zur Startseite")
!
[START](?s=0) <a>INFO</a>
! * ANLAGE
! * WÄRMEPUMPE
!
<a>DIAGNOSE</a>
! * STATUS
! * BUSTEILNEHMER
! * EREIGNISLISTE
! * FACHMANN
!
<a>PROGRAMME</a>
! * HEIZPROGRAMM
! * LÜFTERPROGRAMM
! * PARTYPROGRAMM
! * FERIENPROGRAMM
! * KÜHLZEIT
! * GRUNDEINSTELLUNG
!
<a>EINSTELLUNGEN</a>
! * HEIZEN
! * WARMWASSER
! * LÜFTEN
! * KÜHLEN
! * SOLAR
! * SOMMERBETRIEB
! * ZEIT/DATUM
! * INBETRIEBNAHME
! * FACHMANN
!
<a>PROFIL</a>
! * Netzwerk
! * Sicherheit
! * Anlagenbild
! * SPRACHE
!
WÄRMEPUMPE
!
! <form id="werte" action="#" onsubmit="saveValues(this);return false;">! | PROZESSWERTE |
! HEISSGASTEMPERATUR |
28,6 °C |! HOCHDRUCK |
11,12 bar |! NIEDERDRUCK |
11,10 bar |! VERDAMPFERTEMP. |
27,7 °C |! VERFLÜSSIGERTEMP. |
29,5 °C |! FORTLUFT IST LÜFTERDREHZAHL |
0 Hz |! FORTLUFT SOLL VOLUMENSTROM |
0 % |! | WAERMEMENGEN |
! WM HEIZEN TAG |
0,227 kWh |! WM HEIZEN SUMME |
63,075 MWh |! WM WW TAG |
1,990 kWh |! WM WW SUMME |
10,785 MWh |! WM NE HEIZEN SUMME |
2,721 MWh |! WM NE WW SUMME |
0,167 MWh |! WM WRG TAG |
2,050 kWh |! WM WRG SUMME |
12,038 MWh |! WM SOLAR HZ TAG |
0,000 kWh |! WM SOLAR HZ SUMME |
0,000 MWh |! WM SOLAR WW TAG |
0,000 kWh |! WM SOLAR WW SUMME |
0,000 MWh |! WM KÜHLEN SUMME |
4,770 MWh |! | LEISTUNGSAUFNAHME |
! P HEIZUNG TAG |
0,936 kWh |! P HEIZUNG SUMME |
9,036 MWh |! P WW TAG |
1,500 kWh |! P WW SUMME |
2,108 MWh |! | LAUFZEITEN |
! VERDICHTER HEIZEN |
5435 h |! VERDICHTER KÜHLEN |
421 h |! VERDICHTER WW |
909 h |! ELEKTR. NE HEIZEN |
324 h |! ELEKTR. NE WW |
16 h |! </form>
!![](./pics/ste_footer_website.png)
!
Weitere Informationen zu unserem Produktprogramm und aktuelle Serviceangebote finden Sie unter www.stiebel-eltron.de!
![](./pics/footer_tel.png)
! Unsere Service-Hotline erreichen Sie unter
05531 702 90015!
! Das Neueste rund um die Servicewelt
servicewelt!
[Datenschutz](?s=1,2&arch=datenschutzerklaerung)
! v8.5.3
!© STIEBEL ELTRON 2016
! ````
das wäre der quellcode einer der Seiten die ich parsen möchte.@pix: danke für den Tipp. Mir wäre es lieber, wenn ich bei iobroker Adapter bleibe um nicht irgendwann den Überblick zu verlieren und die Komplexität "etwas" im Rahmen halten zu können.
Beste Grüße
-
Heissgastemperatur:
HEISSGASTEMPERATUR.+\n.+>(\d+,\d+)
Niederdruck:
NIEDERDRUCK.+\n.+>(\d+,\d+)
Verdampfertemperatur:
VERDAMPFERTEMP.+\n.+>(\d+,\d+)
Verflüssigertemperatur:
VERFLÜSSIGERTEMP.+\n.+>(\d+,\d+)
usw.
Im Prinzip muss immer nur die Bezeichnung ausgetaucht werden: HEISSGASTEMPERATUR -> NIEDERDRUCK
Je benötigten Wert eine RegEx-Abfrage.
-
Hi ruhr70,
vielen Dank für deine Hilfe.
Beim eingeben der Regeln funktioniert soweit noch alles.
Ich habe jetzt 4 Regeln angelegt zum Testen, aber sobald der parser adapter daraufhin neustartet kommt folgende FM im Log:
parser.0 2017-05-18 22:20:03.453 info starting. Version 0.2.1 in C:/Program Files/ioBroker/node_modules/iobroker.parser, node: v4.5.0 host.SERVER 2017-05-18 22:20:02.470 info instance system.adapter.parser.0 started with pid 9488 host.SERVER 2017-05-18 22:20:00.017 info instance system.adapter.parser.0 terminated with code null () host.SERVER 2017-05-18 22:20:00.017 warn instance system.adapter.parser.0 terminated due to SIGTERM host.SERVER 2017-05-18 22:19:59.954 info stopInstance system.adapter.parser.0 killing pid 3284 host.SERVER 2017-05-18 22:19:59.954 info stopInstance system.adapter.parser.0 host.SERVER 2017-05-18 22:19:59.954 info object change system.adapter.parser.0 parser.0 2017-05-18 22:18:56.329 info starting. Version 0.2.1 in C:/Program Files/ioBroker/node_modules/iobroker.parser, node: v4.5.0 host.SERVER 2017-05-18 22:18:55.423 info instance system.adapter.parser.0 started with pid 3284 host.SERVER 2017-05-18 22:18:25.360 info Restart adapter system.adapter.parser.0 because enabled host.SERVER 2017-05-18 22:18:25.360 error instance system.adapter.parser.0 terminated with code 0 (OK) parser.0 2017-05-18 22:18:24.813 error at Timer.listOnTimeout (timers.js:92:15) parser.0 2017-05-18 22:18:24.813 error at ontimeout [as _onTimeout] (timers.js:209:34) parser.0 2017-05-18 22:18:24.813 error at _analyseDataForStates (C:\Program Files\ioBroker\node_modules\iobroker.parser\main.js:125:9) parser.0 2017-05-18 22:18:24.813 error at analyseData (C:\Program Files\ioBroker\node_modules\iobroker.parser\main.js:159:26) parser.0 2017-05-18 22:18:24.813 error TypeError: Cannot read property 'exec' of undefined parser.0 2017-05-18 22:18:24.813 error uncaught exception: Cannot read property 'exec' of undefined sql.0 2017-05-18 22:18:23.470 info enabled logging of parser.0.P_WW_Tag parser.0 2017-05-18 22:18:22.735 info starting. Version 0.2.1 in C:/Program Files/ioBroker/node_modules/iobroker.parser, node: v4.5.0 host.SERVER 2017-05-18 22:18:21.688 info instance system.adapter.parser.0 started with pid 15432 web.0 2017-05-18 22:18:18.704 info 2017-05-18T20:18:18.704Z Connected system.user.admin sql.0 2017-05-18 22:18:17.423 info No Data sql.0 2017-05-18 22:18:12.486 info enabled logging of parser.0.P_WW_Summe web.0 2017-05-18 22:18:06.876 info 2017-05-18T20:18:06.876Z Connected system.user.admin sql.0 2017-05-18 22:18:05.642 info No Data sql.0 2017-05-18 22:18:01.439 info enabled logging of parser.0.P_Heizung_Tag web.0 2017-05-18 22:17:56.673 info 2017-05-18T20:17:56.673Z Connected system.user.admin sql.0 2017-05-18 22:17:55.251 info No Data host.SERVER 2017-05-18 22:17:51.689 info Restart adapter system.adapter.parser.0 because enabled
und unter Objekte sehe ich zwar die Einträge, aber es erscheinen keine Werte…
-
Das der Adapter abstürzt sollte nicht sein, egal was man eingetragen hat.
Das müsste sich der Adapterentwickler mal ansehen.
Versuch mal bitte die Rolle auf "Wert" zu stellen und den Typ auf "String".
Funktioniert es dann?
-
Wenn ich auf Wert und String umstelle erscheint folgendes im Log.
parser.0 2017-05-19 08:22:06.032 info starting. Version 0.2.1 in C:/Program Files/ioBroker/node_modules/iobroker.parser, node: v4.5.0 host.SERVER 2017-05-19 08:22:04.922 info instance system.adapter.parser.0 started with pid 14420 host.SERVER 2017-05-19 08:22:02.454 info instance system.adapter.parser.0 terminated with code null () host.SERVER 2017-05-19 08:22:02.454 warn instance system.adapter.parser.0 terminated due to SIGTERM host.SERVER 2017-05-19 08:22:02.407 info stopInstance system.adapter.parser.0 killing pid 20696 host.SERVER 2017-05-19 08:22:02.407 info stopInstance system.adapter.parser.0 host.SERVER 2017-05-19 08:22:02.391 info object change system.adapter.parser.0 parser.0 2017-05-19 08:20:14.657 info starting. Version 0.2.1 in C:/Program Files/ioBroker/node_modules/iobroker.parser, node: v4.5.0 host.SERVER 2017-05-19 08:20:13.736 info instance system.adapter.parser.0 started with pid 20696 host.SERVER 2017-05-19 08:20:11.283 info instance system.adapter.parser.0 terminated with code null () host.SERVER 2017-05-19 08:20:11.283 warn instance system.adapter.parser.0 terminated due to SIGTERM host.SERVER 2017-05-19 08:20:11.205 info stopInstance system.adapter.parser.0 killing pid 9488 host.SERVER 2017-05-19 08:20:11.205 info stopInstance system.adapter.parser.0 host.SERVER 2017-05-19 08:20:11.205 info object change system.adapter.parser.0 sql.0 2017-05-19 08:20:11.188 info enabled logging of parser.0.P_Heizung_Summe sql.0 2017-05-19 08:20:11.157 info enabled logging of parser.0.P_Heizung_Tag sql.0 2017-05-19 08:20:11.141 info enabled logging of parser.0.P_WW_Tag sql.0 2017-05-19 08:20:11.126 info enabled logging of parser.0.P_WW_Summe
Werte tauchen unter Objekte aber leider ebenfalls nicht auf
-
Wenn ich auf Wert und String umstelle erscheint folgendes im Log. `
Ich habe das mal nachgebaut… über einen Webserver verlangt er bei der Auswertung noch einen "Carriage Return". Das "Linefeed" alleine hatte da nicht ausgereicht.
Versuche mal bitte:
VERDAMPFERTEMP.+\r\n.+>(\d+,\d+)
Das \r ist dazugekommen.
So funktioniert es bei mir dann nicht nur über Online-Regex, sondern auch über einen Webserver:
-
Ich habe jetzt auf git die neue Version. Die sollte mehr Fehler abfangen und kann nicht nur ersten Element finden. Sondern z.B. dritte.
-
Hi Ruhr70,
vielen Dank für deine Hilfe.
Jetzt klappts perfekt !
30 Regeln anlegen dauert ein ganz schönes Weilchen.
Eine große Hilfe wäre wenn man die Möglichkeit hätte Regeln zu duplizieren und sie dann nur noch anpassen zu müssen…
Beste Grüße
-
Hi Ruhr70,
vielen Dank für deine Hilfe.
Jetzt klappts perfekt !
30 Regeln anlegen dauert ein ganz schönes Weilchen.
Eine große Hilfe wäre wenn man die Möglichkeit hätte Regeln zu duplizieren und sie dann nur noch anpassen zu müssen…
Beste Grüße `
Trello? -