Wetter und Wettervorhersagen: Unterschied zwischen den Versionen
K (Noch einen Link auf HTTPMOD umgestellt) |
Fabian (Diskussion | Beiträge) K (→Links: Link eingefügt) |
||
Zeile 215: | Zeile 215: | ||
* [http://bloglich.de/art/rpi/wetterdaten-auf-dem-raspberry-pi-in-fhem/ Beispiel in Blog(de)] | * [http://bloglich.de/art/rpi/wetterdaten-auf-dem-raspberry-pi-in-fhem/ Beispiel in Blog(de)] | ||
* [[HTTPMOD]] | * [[HTTPMOD]] | ||
* [[GDS|Modul GDS]] zum Auslesen von DWD-Daten | |||
[[Kategorie:Code Snippets]] | [[Kategorie:Code Snippets]] |
Version vom 24. Februar 2015, 21:26 Uhr
Wetterdaten und Wettervorhersagen können auf verschiedene Weise in Fhem eingebunden werden.
Yahoo-Wetter
Für die einfache Einbindung des Yahoo-Wetters gibt es das spezielle Modul Weather.
Wetterwarnungen des DWD
Der Deutsche Wetterdienst DWD stellt neben diversen Wetterdaten auch Wetterwarnungen bereit. Diese können sehr einfach via weblink iframe in Fhem eingebunden werden - das ist zwar nicht die schönste Form, aber die schnellste.
Dazu sucht man sich zuerst auf der Warnungsseite des DWD die eigene Region heraus (in der Karte durchklicken). Die gewünschte URL für Berlin Stadt ist z.B. http://www.dwd.de/dyn/app/ws/html/reports/BXX_warning_de.html#WS_ANCHOR_0
. Das Anhängsel #WS_ANCHOR_0
kann man in der Konfiguration auch weglassen.
Die Einbindung in Fhem sieht dann wie folgt aus:
define dwd_warnmeldung weblink iframe http://www.dwd.de/dyn/app/ws/html/reports/BXX_warning_de.html attr dwd_warnmeldung group Wetterwarnungen (DWD) attr dwd_warnmeldung htmlattr width="100%" height="300" frameborder="0" marginheight="0" marginwidth="0" attr dwd_warnmeldung room Wettervorhersage,Startseite
Vorhersage-Diagramm von YR
YR ist die Seite des norwegischen Wetterdiensts. Er ist zwar nur in Teilen auf Englisch (und gar nicht auf Deutsch) verfügbar, bietet aber sehr gute Wettervorhersagen - auch mit eigenen Vorhersagen für kleine Dörfer. Neben etlichen Detailinfos bietet YR eine sehr schicke 48h-Vorhersage-Grafik. Diese kann sehr einfach via weblink iframe in Fhem eingebunden werden.
Dazu geht man auf die Startseite von YR und gibt in das Suchfeld den Namen seines Dörfchens ein - die Ergebnissliste kann ziemlich lang werden, sodass man evtl. sehr genau schauen muss, welches das eigene Kaff ist - bei mir war es an 29. Stelle... ;-) Auf der gewünschten Seite gibt es einen Unterpunkt "Hour by hour", wo sich die besagte Grafik findet. Hier kopiert man sich einfach die URL der Grafik.
Die Einbindung in Fhem sieht dann bspw. wie folgt aus:
define Wetter_yr_Vorhersage weblink iframe http://www.yr.no/place/Germany/Berlin/Berlin/meteogram.png attr Wetter_yr_Vorhersage group Wettervorhersage (yr) attr Wetter_yr_Vorhersage htmlattr width="100%" height="300" frameborder="0" marginheight="0" marginwidth="0" attr Wetter_yr_Vorhersage room Wettervorhersage,Start
Wetter von Weather Underground
Hinweis: Dieses Vorgehen ist etwas anspruchsvoller und somit eher für erfahrene fhem-user geeignet.
Weather Underground ist bietet eine sehr umfassende Sammlung aller möglichen offiziellen und privaten (aber teils sehr professionellen) Wetterstationen weltweit. Es besteht eine recht hohe Wahrscheinlichkeit, dass es in der eigenen Umgebung schon eine Wetterstation gibt. Anstatt nun selbst eine komplette Wetterstation aufzubauen, kann man alternativ auf die Daten der Nachbarstation zugreifen.
Dazu sind grundsätzlich die folgenden Schritte notwendig:
- Finden der geeigneten Station
- Auswerten der XML-Daten
- Erstellen passender gplot-Dateien
Finden der geeigneten Station
Als erstes geht man auf die Startseite von Weather Underground und gibt in das Suchfeld den Namen seines Dörfchens oder der nächsten Stadt ein - für Berlin landet man bspw. auf Seite für "Berlin Alexanderplatz". Es gibt aber manchmal sehr viele Wetterstationen in der direkten Umgebung. Diese findet man indem am auf "Change Station" klickt und sich eine passende Station aussucht. Nähere Infos (zB. zur verwendeten Hard- und Software) zu der gewählten Wetterstation erhält man, wenn man auf den Namen der Station klickt und dann auf "About this PWS".
Weather Underground stellt die Daten der Wetterstation auch über eine API als XML bereit, die wir auswerten können. Die entsprechende URL findet sich ebenfalls unter "About this PWS" unter "Download current conditions XML". Für Berlin Prenzlauer Berg wäre dies bspw.
http://api.wunderground.com/weatherstation/WXDailyHistory.asp?ID=IBERLIN15&format=XML
.
Auswerten der XML-Daten
Die Auswertung der XML-Daten erfolgt via HTTPMOD. Da dies nicht ganz trivial ist, sind im Folgenden zuerst die wesentlichen Konfigurationsschritte exemplarisch beschrieben. Weiter unten findet sich dann die fertige vollständige Konfiguration.
Es erstes wird das Device HTTPMOD definiert (die 600 am Schluss ist der Aktualisierungszyklus in Sekunden, also alle 10 min):
define wetter_prenzelberg HTTPMOD http://api.wunderground.com/weatherstation/WXCurrentObXML.asp?ID=IBERLIN15 600
Dann werden Attribute für alle Readings definiert:
attr wetter_prenzelberg userattr readingsName_cloudiness readingsName_date ...
Dann wird jedem Attribut ein Name zugewiesen (unter diesem Namen wird der Wert ins Log geschrieben):
attr wetter_prenzelberg readingsName_cloudiness cloudiness
Zum Schluss wird das Reading selbst definiert:
attr wetter_prenzelberg readingsRegex_cloudiness cloudiness id="NN" percent="([\d\.]+)
Die gesamte Konfiguration für alle von der API angebotenen Wetterwerte sieht dann wie folgt aus:
define wetter_prenzelberg HTTPMOD http://api.wunderground.com/weatherstation/WXCurrentObXML.asp?ID=IBERLIN15 600 attr wetter_prenzelberg userattr readingsName_cloudiness readingsName_date readingsName_dewpointTemperature readingsName_fog readingsName_heatindex readingsName_humidity readingsName_pressure readingsName_solarRadiation readingsName_solarUV readingsName_temperature readingsName_time readingsName_windChill readingsName_windDegrees readingsName_windDirection readingsName_windGust readingsName_windSpeed readingsRegex_cloudiness readingsRegex_date readingsRegex_dewpointTemperature readingsRegex_fog readingsRegex_heatindex readingsRegex_humidity readingsRegex_pressure readingsRegex_solarRadiation readingsRegex_solarUV readingsRegex_temperature readingsRegex_time readingsRegex_windChill readingsRegex_windDegrees readingsRegex_windDirection readingsRegex_windGust readingsRegex_windSpeed attr wetter_prenzelberg readingsName_cloudiness cloudiness attr wetter_prenzelberg readingsName_date date attr wetter_prenzelberg readingsName_dewpointTemperature dewpointTemperature attr wetter_prenzelberg readingsName_fog fog attr wetter_prenzelberg readingsName_heatindex heatindex attr wetter_prenzelberg readingsName_humidity humidity attr wetter_prenzelberg readingsName_pressure pressure attr wetter_prenzelberg readingsName_solarRadiation solarRadiation attr wetter_prenzelberg readingsName_solarUV solarUV attr wetter_prenzelberg readingsName_temperature temperature attr wetter_prenzelberg readingsName_time time attr wetter_prenzelberg readingsName_windChill windChill attr wetter_prenzelberg readingsName_windDegrees windDegrees attr wetter_prenzelberg readingsName_windDirection windDirection attr wetter_prenzelberg readingsName_windGust windGust attr wetter_prenzelberg readingsName_windSpeed windSpeed attr wetter_prenzelberg readingsRegex_cloudiness cloudiness id="NN" percent="([\d\.]+) attr wetter_prenzelberg readingsRegex_date date date" content="([\d\.]+) attr wetter_prenzelberg readingsRegex_dewpointTemperature <dewpoint_c>([\d\.]+) attr wetter_prenzelberg readingsRegex_fog fog id="FOG" percent="([\d\.]+) attr wetter_prenzelberg readingsRegex_heatindex <heat_index_c>([\d\.]+) attr wetter_prenzelberg readingsRegex_humidity <relative_humidity>([\d\.]+) attr wetter_prenzelberg readingsRegex_pressure <pressure_mb>([\d\.]+) attr wetter_prenzelberg readingsRegex_solarRadiation <solar_radiation>([\d\.]+) attr wetter_prenzelberg readingsRegex_solarUV <UV>([\d\.]+) attr wetter_prenzelberg readingsRegex_temperature <temp_c>([\d\.]+) attr wetter_prenzelberg readingsRegex_time time Zeit([\d\:]+) attr wetter_prenzelberg readingsRegex_windChill <windchill_c>([\d\.]+) attr wetter_prenzelberg readingsRegex_windDegrees <wind_degrees>([\d\.]+) attr wetter_prenzelberg readingsRegex_windDirection <wind_dir>([\d\.]+) attr wetter_prenzelberg readingsRegex_windGust <wind_gust_mph>([\d\.]+) attr wetter_prenzelberg readingsRegex_windSpeed <wind_mph>([\d\.]+)
Hinweis: Nicht immer werden alle Werte geliefert (wenn keine Sonne, dann kein UV-Wert...). Im System-Log kann das als Fehler auftauchen, ist aber kein Problem.
Erstellen passender gplot-Dateien
Um die ausgelesenen Werte als Graphen darstellen zu können müssen eigene gplot-Dateien erstellt werden. Eine grundsätzliche Anleitung dazu findet sich unter Creating Plots. Deshalb sollen hier nur Beispiele für die eigentlichen gplot-Dateien vorgestellt werden. Beispiele sollten sowohl für FileLog wie DbLog funktionieren.
Temperatur und Luftfeuchte:
set terminal png transparent size <SIZE> crop set output '<OUT>.png' set xdata time set timefmt "%Y-%m-%d_%H:%M:%S" set xlabel " " #set title '<L1>' set title '' set ytics set y2tics set grid ytics set ylabel "Temperature in C" set y2label "Humidity (%)" #FileLog 4:temperature\x3a:: #FileLog 4:windChill\x3a:: #FileLog 4:humidity\x3a:: #DbLog <SPEC1>:temperature:: #DbLog <SPEC1>:windChill:: #DbLog <SPEC1>:humidity:: plot "<IN>" using 1:2 axes x1y1 title 'Temperatur (C)' ls l0 lw 1.5 with lines,\ "<IN>" using 1:2 axes x1y1 title 'Gefühlte Temperatur (C)' ls l1 lw 1.5 with lines,\ "<IN>" using 1:2 axes x1y2 title 'Luftfeuchtigkeit (%)' ls l2fill lw 0.2 with lines
Wind und Windrichtung:
set terminal png transparent size <SIZE> crop set output '<OUT>.png' set xdata time set timefmt "%Y-%m-%d_%H:%M:%S" set xlabel " " set ytics set y2tics ("Nord" 0, "Ost" 80, "Süd" 180, "West" 270, "Nord" 360) #set title '<L1>' set title '' set grid xtics ytics set yrange [0:20] set y2range [0:360] set ylabel "Wind (km/h)" set y2label "Richtung" #FileLog 4:windSpeed:0: #FileLog 4:windGust:0: #FileLog 4:windDegrees:0: #DbLog <SPEC1>:windSpeed:: #DbLog <SPEC1>:windGust:: #DbLog <SPEC1>:windDegrees:: plot "<IN>" using 1:2 axes x1y1 title 'Wind (km/h)' ls l0 lw 1.5 with lines,\ "<IN>" using 1:2 axes x1y1 title 'Böen (km/h)' ls l1 lw 1.5 with lines,\ "<IN>" using 1:2 axes x1y2 title 'Windrichtung (°)' ls l2fill lw 0.2 with points
Sonnenintensität und UV-Werte:
set terminal png transparent size <SIZE> crop set output '<OUT>.png' set xdata time set timefmt "%Y-%m-%d_%H:%M:%S" set xlabel " " set ytics set y2tics #set title '<L1>' set title '' set grid xtics ytics set ylabel "Sonnenstrahlung (W/qm)" set y2label "UV" #FileLog 4:solarRadiation:0: #FileLog 4:solarUV:0: #DbLog <SPEC1>:solarRadiation:: #DbLog <SPEC1>:solarUV:: plot "<IN>" using 1:2 axes x1y1 title 'Strahlung' ls l0 lw 1.5 with lines,\ "<IN>" using 1:2 axes x1y1 title 'UV' ls l1 lw 1.5 with lines
Weitere TBD
Vergangene Daten abfragen
Ein konkretes vergangenes Datum der Wetterstation kann man übrigens auch abrufen - für den 28.11.2014 wäre dies bspw.
http://www.wunderground.com/weatherstation/WXDailyHistory.asp?ID=IBERLIN15&day=28&month=11&year=2014&graphspan=day&format=1
.
Links
- Thema mit Sammlung und Beipielen von Internet-Links für die Anzeige von teilweise animierten Wetterbildern
- Beispiel in Blog(de)
- HTTPMOD
- Modul GDS zum Auslesen von DWD-Daten