modified: app.py

modified:   templates/index.html
This commit is contained in:
SimolZimol
2024-09-10 13:26:32 +02:00
parent 9c8837fd3f
commit b2ff2b65f6
2 changed files with 50 additions and 91 deletions

81
app.py
View File

@@ -1,61 +1,44 @@
import requests
import bz2
import json
from flask import Flask, jsonify, render_template
from flask import Flask, render_template
app = Flask(__name__)
# Funktion, um die bz2-Datei herunterzuladen und zu entpacken
def download_and_extract_data():
url = "https://opendata.dwd.de/weather/weather_reports/synoptic/germany/json/Z__C_EDZW_latest_bda01,synop_bufr_GER_999999_999999__MW_XXX.json.bz2"
# URL der DWD-OpenData JSON-Datei
DWD_URL = "https://opendata.dwd.de/weather/weather_reports/synoptic/germany/json/Z__C_EDZW_latest_bda01%2Csynop_bufr_GER_999999_999999__MW_XXX.json.bz2"
def download_and_parse_dwd_data():
response = requests.get(DWD_URL)
# Lade die bz2-Datei herunter
response = requests.get(url)
if response.status_code == 200:
# Entpacke die bz2-Datei
decompressed_data = bz2.decompress(response.content)
return json.loads(decompressed_data)
else:
return None
# Die Daten mit bz2 entpacken und dekodieren
decompressed_data = bz2.decompress(response.content)
weather_data = json.loads(decompressed_data)
# Daten nach stationNumber sortieren
sorted_weather_data = {}
for message in weather_data['messages']:
for subset in message[1]:
station_number = subset[0]["value"]
station_data = {}
for entry in subset:
key = entry["key"]
value = entry.get("value")
station_data[key] = value
# Speichere die Daten sortiert nach stationNumber
sorted_weather_data[station_number] = station_data
return sorted_weather_data
# Funktion, um die Wetterdaten nach Station zu sortieren
def extract_and_sort_weather_data():
data = download_and_extract_data()
if data:
weather_data = []
# Extrahiere die Wetterdaten, die nach 'stationNumber' sortiert werden
for message in data.get('messages', []):
for station_data in message[1:]:
weather_info = {}
for item in station_data:
if isinstance(item, dict):
if item['key'] == 'stationNumber':
weather_info['stationNumber'] = item['value']
elif item['key'] == 'stationOrSiteName':
weather_info['stationName'] = item['value']
elif item['key'] == 'airTemperature':
weather_info['airTemperature'] = item['value'] - 273.15 # Kelvin to Celsius
elif item['key'] == 'windSpeed':
weather_info['windSpeed'] = item['value']
elif item['key'] == 'pressureReducedToMeanSeaLevel':
weather_info['pressure'] = item['value']
elif item['key'] == 'relativeHumidity':
weather_info['humidity'] = item['value']
if 'stationNumber' in weather_info:
weather_data.append(weather_info)
# Sortiere die Wetterdaten nach 'stationNumber'
sorted_weather_data = sorted(weather_data, key=lambda x: x['stationNumber'])
return sorted_weather_data
else:
return []
# Flask-Route, um die Wetterdaten anzuzeigen
@app.route('/')
def weather():
weather_data = extract_and_sort_weather_data()
def home():
# Daten von DWD herunterladen und parsen
weather_data = download_and_parse_dwd_data()
# Daten an die HTML-Seite übergeben
return render_template('index.html', weather_data=weather_data)
if __name__ == '__main__':
app.run(host='0.0.0.0', port=5000)
app.run(debug=True, host='0.0.0.0', port=5000)

View File

@@ -3,49 +3,25 @@
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Wetterdaten</title>
<style>
table {
width: 100%;
border-collapse: collapse;
}
table, th, td {
border: 1px solid black;
}
th, td {
padding: 8px;
text-align: left;
}
th {
background-color: #f2f2f2;
}
</style>
<title>Wetterdaten nach Station</title>
<link rel="stylesheet" href="/static/style.css">
</head>
<body>
<h1>Wetterdaten sortiert nach Station</h1>
<table>
<thead>
<tr>
<th>Stationsnummer</th>
<th>Stationsname</th>
<th>Temperatur (°C)</th>
<th>Windgeschwindigkeit (m/s)</th>
<th>Luftdruck (Pa)</th>
<th>Luftfeuchtigkeit (%)</th>
</tr>
</thead>
<tbody>
{% for data in weather_data %}
<tr>
<td>{{ data.stationNumber }}</td>
<td>{{ data.stationName }}</td>
<td>{{ data.airTemperature }}</td>
<td>{{ data.windSpeed }}</td>
<td>{{ data.pressure }}</td>
<td>{{ data.humidity }}</td>
</tr>
{% endfor %}
</tbody>
</table>
<h1>Wichtige Wetterdaten sortiert nach Station</h1>
{% for station, data in weather_data.items() %}
<div class="station">
<h2>Station Nummer: {{ station }}</h2>
<ul>
<li><strong>Station Name:</strong> {{ data.get('stationOrSiteName', 'N/A') }}</li>
<li><strong>Latitude:</strong> {{ data.get('latitude', 'N/A') }}</li>
<li><strong>Longitude:</strong> {{ data.get('longitude', 'N/A') }}</li>
<li><strong>Luftdruck:</strong> {{ data.get('pressureReducedToMeanSeaLevel', 'N/A') }} Pa</li>
<li><strong>Temperatur:</strong> {{ data.get('airTemperature', 'N/A') }} K</li>
<li><strong>Windgeschwindigkeit:</strong> {{ data.get('windSpeed', 'N/A') }} m/s</li>
<li><strong>Windrichtung:</strong> {{ data.get('windDirection', 'N/A') }} °</li>
</ul>
</div>
{% endfor %}
</body>
</html>