Staumelder: Unterschied zwischen den Versionen
Krikan (Diskussion | Beiträge) K (Verlinkung / code-Tags repariert) |
|||
Zeile 22: | Zeile 22: | ||
* http://hessenschau.de/index.html | * http://hessenschau.de/index.html | ||
Für das Modul | Für das Modul werden die Perlmodule HTML::TreeBuilder::XPath sowie libjson-perl benötigt. | ||
Installiert werden | Installiert werden können diese mit nachfolgendem Befehl. | ||
:<code>sudo apt-get install libxml-treebuilder-perl libhtml-treebuilder-xpath-perl</code> | :<code>sudo apt-get install libxml-treebuilder-perl libhtml-treebuilder-xpath-perl</code> | ||
:<code> sudo apt-get install libjson-perl </code> | |||
Die Grundsätzliche Definition des Moduls sieht wie Folgt aus: | Die Grundsätzliche Definition des Moduls sieht wie Folgt aus: | ||
Zeile 52: | Zeile 53: | ||
=== Zusätzliche Einstellungen === | === Zusätzliche Einstellungen === | ||
Neues Attribut für die Formatierung der Meldungen (Voranstellen von Strasse, Richtung, beides oder keines von beiden --> siehe commandref) (nur für Verkehrsinfo.de Verfügbar) | |||
{{Randnotiz|RNText= | {{Randnotiz|RNText= | ||
Zeile 57: | Zeile 60: | ||
aber es kann auch wahlweise nur einer verwendet werden. | aber es kann auch wahlweise nur einer verwendet werden. | ||
Die Filter sind mit einem Logischen UND verknüpft. | Die Filter sind mit einem Logischen UND verknüpft. | ||
Das | Das heißt z.B.: wenn etwas ausgeschlossen wurde, | ||
kann es nicht mit dem Einschlussfilter | kann es nicht mit dem Einschlussfilter wieder geholt werden.}} | ||
Das Modul erlaubt das Filtern von Meldungen anhand von Attributen wie '''filter_exclude''' und '''filter_include'''. | Das Modul erlaubt das Filtern von Meldungen anhand von Attributen wie '''filter_exclude''' und '''filter_include'''. | ||
Zeile 66: | Zeile 69: | ||
:<code>attr Staumeldungen filter_exclude Baustelle | Sperrung </code> | :<code>attr Staumeldungen filter_exclude Baustelle | Sperrung </code> | ||
:<code>attr Staumeldungen filter_include Frankfurt | Unfall</code> | :<code>attr Staumeldungen filter_include Frankfurt | Unfall</code> | ||
Die neuste Version erlaubt auch eine Sortierung der Meldung anhand der z.B Strasse. | |||
Dazu muss das Attribute '''orderby''' gesetzt werden | |||
:<code>attr Staumeldungen orderby A3 | A5 </code> | |||
{{Randnotiz|RNText= | |||
Das Attribute msg_format ist nur für Verkehrsinfo.de verfügbar | |||
}} | |||
Mit Hilfe des Attributes msg_format kann die Meldung (Voranstellen von Strasse, Richtung, beides oder keines von beiden ) formatiert werden. | |||
:<code>attr Staumeldungen msg_format road </code> | |||
Zeile 163: | Zeile 180: | ||
Attribut zur Priorisierung von Meldungen | Attribut zur Priorisierung von Meldungen | ||
== Das TRAFFIC Modul == | == Das TRAFFIC Modul == |
Version vom 23. Oktober 2016, 17:50 Uhr
Vorüberlegungen
Die Überlegung sich Stau. - und Verkehrsmeldung per FHEM bereitstellen zu lassen klingt verlockend. Für die Realisierung wurden mehrere Wege betrachtet.
Umsetzungen
Es gibt bereits mehrere Möglichkeiten Stau.- und Verkehrsmeldung mit FHEM auszulesen und darzustellen
- Stau. - und Verkehrsmeldung über das Modul Verkehrsinfo
- Stau. - und Verkehrsmeldung per HTTPMOD
- Stau. - und Verkehrsmeldung über Google Maps
Das Verkehrsinfo Modul
Das Modul Verkehrsinfo bietet für Stau. - und Verkehrsmeldung- eine übersichtliche Möglichkeit die potentiellen Meldungen anzeigen zu lassen. Dabei bedient es sich aktuell aus zwei Webseiten.
Für das Modul werden die Perlmodule HTML::TreeBuilder::XPath sowie libjson-perl benötigt. Installiert werden können diese mit nachfolgendem Befehl.
sudo apt-get install libxml-treebuilder-perl libhtml-treebuilder-xpath-perl
sudo apt-get install libjson-perl
Die Grundsätzliche Definition des Moduls sieht wie Folgt aus:
define <name> Verkehrsinfo <url> <interval>
Aktuell Mögliche Varianten
"Verkehrsinfo.de"
Über die Webseite verkehrsinfo.de können die Stau. - und Verkehrsmeldungen von ganz Deutschland abgefragt werden. Dabei kann über die Webseite nach Bundesland oder Strassentyp gefiltert werden. Aus dieser Filterung wird auch der anschließend benötigte Link für das Modul generiert.
Eine Beispielkonfiguration anhand der Filterung auf einen Strassentyp. Abfrageintervall hier 3600 Sekunden.
define A66 Verkehrsinfo https://www.verkehrsinfo.de/index.php?country=1&street=A66&UIN= 3600
"hessenschau.de"
Über die Webseite hessenschau.de können die Stau. - und Verkehrsmeldungen von Hessen abgefragt werden. Eine Filterung auf bestimmte Strassentypen ist über die zusätzlichen Attribute filter_exclude sowie filter_include möglich.
Eine Beispielkonfiguration mit Abfrageintervall von 3600 Sekunden.
define Staumelder Verkehrsinfo http://hessenschau.de/verkehr/index.html 3600
Zusätzliche Einstellungen
Neues Attribut für die Formatierung der Meldungen (Voranstellen von Strasse, Richtung, beides oder keines von beiden --> siehe commandref) (nur für Verkehrsinfo.de Verfügbar)
aber es kann auch wahlweise nur einer verwendet werden. Die Filter sind mit einem Logischen UND verknüpft. Das heißt z.B.: wenn etwas ausgeschlossen wurde,
kann es nicht mit dem Einschlussfilter wieder geholt werden.
Das Modul erlaubt das Filtern von Meldungen anhand von Attributen wie filter_exclude und filter_include.
Dabei werden die geladenen Meldung nach bestimmten Schlagwörtern durchsucht und somit nur die Meldung in Readings
gespeichert, für die einer der beiden Attribute zutrifft.
attr Staumeldungen filter_exclude Baustelle | Sperrung
attr Staumeldungen filter_include Frankfurt | Unfall
Die neuste Version erlaubt auch eine Sortierung der Meldung anhand der z.B Strasse.
Dazu muss das Attribute orderby gesetzt werden
attr Staumeldungen orderby A3 | A5
Mit Hilfe des Attributes msg_format kann die Meldung (Voranstellen von Strasse, Richtung, beides oder keines von beiden ) formatiert werden.
attr Staumeldungen msg_format road
Die Funktion kann überall in FHEM aufgerufen werden und liefert als Rückgabewert das gleiche Ergebnis wie der get <name> info Aufruf.
Der Rückgabewert als Text, kann dann für weiteres verwendet werden.
Verkehrsinfo_GetData(<devicename>)
my $result = Verkehrsinfo_GetData('A8')
Vorlesen von Meldungen
Die Meldungen aus den Readings lassen sich auch mit FHEM vorlesen. Dazu bedarfs es einem System, welches Text in Sprache (TTS) umwandeln kann. Hier bietet sich das Modul TTS oder z.b ein Sonossystem an. Auch weitere System zum Vorlesen von Meldungen sind Nutzbar.
Folgendes Beispiel zeigt ein at welches dynamisch anhand der Meldungsanzahl eine Variable füllt. Diese Variable wird dann von einem Sonossystem oder alternativ einem TTS System vorgelesen.
define Staumelder at*05:36:00 { my $stau_counter = ReadingsVal("Stau","count",""); my $stau = "Es liegen " . " " . "$stau_counter" ." Staumeldungen um ". TimeNow() ." vor:"; my $complete_message; ## Anhand Meldungszahl das Reading in der Schleife zusammenbauen my $reading_pre="e_"; my $reading_suff="_msg"; my $reading; ## Iterationsvariable my $i = 0; while ($stau_counter >= $i) { $reading = "$reading_pre" . "$i" . "$reading_suff"; $complete_message = "$complete_message" .".". ReadingsVal("Stau",$reading ,""); $i++; } fhem "set Staudummy $stau$complete_message "; fhem "set MeinSonossystem Speak 50 de $stau$complete_message"; fhem "set MeinTTS tts $stau$complete_message"; }
Senden von Meldungen per Messenger
Befindet man sich allerdings nicht zu Hause und möchte dennoch wissen, ob es im definierten Bereich Verkehsbehinderung gibt, können die Meldungen auch per Messenger Modul zugesendet werden.
Jabber
Wenn das Jabbermodul bereits installiert und konfiguriert wurde kann mit folgendem Code in der 99_myUtils.pm das Abrufen von Staumeldungen implementiert werden. Der Code bezieht sich dabei auf die Grundeinrichtung des Jabbermoduls von hier: FHEM spricht jabber
# Staumeldung abrufen if($cmd eq "stau") { fhem("set Staumeldungen update"); $newmsg.= "Staumeldungen von: "; $newmsg.=ReadingsVal("Staumeldungen", "date_time", "---").":::"; $newmsg=$newmsg."\n"; $newmsg.=ReadingsVal("Staumeldungen", "e_1_msg", "---")." , "; $newmsg=$newmsg."\n"; $newmsg.=ReadingsVal("Staumeldungen", "e_2_msg", "---")." , "; $newmsg=$newmsg."\n"; $newmsg.=ReadingsVal("Staumeldungen", "e_3_msg", "---")." , "; $newmsg=$newmsg."\n"; $newmsg.=ReadingsVal("Staumeldungen", "e_4_msg", "---")." , "; $newmsg=$newmsg."\n"; $newmsg.=ReadingsVal("Staumeldungen", "e_5_msg", "//Ende")."."; }
telegram
Das telegram Modul muss bereits installiert sein. Optional das Verkehsmodul anlegen und konfigurieren.
define traffic.a8 Verkehrsinfo https://www.verkehrsinfo.de/httpsmobil/index.php?c=staulist&street=A8&lat=&lon= 3600
Mit Hilfe des Notify können die Meldung per TelegramBot versendet werden.
define ntf.telebot.traffic notify telebot.msgText:\s(?i)stau.* {\ my $msgpeer = ReadingsVal('telebot', 'msgPeer','');;\ fhem("set traffic.a8 update");;\ fhem("set telebot message @". $msgpeer . " " . Verkehrsinfo_GetData('traffic.a8'));;\ }
Bekannte Probleme / Fehlermeldungen
Can't call method "as_trimmed_text" on an undefined value at ./FHEM/98_Verkehrsinfo.pm line 220.
Die obiger Fehlermeldung wird durch Änderungen der Webseiten hervorgerufen. Hier muss ggf. das Modul angepasst/erweitert werden.
Ideen
Attribut zur Priorisierung von Meldungen
Das TRAFFIC Modul
Mit diesem Modul können eigene Wegstrecken, und deren Verkehr, über Google Maps Directions API erfasst werden. Das Modul sowie die Grundeinstellungen sind im Modulartikel TRAFFIC beschrieben.