modified: app.py
This commit is contained in:
53
app.py
53
app.py
@@ -21,30 +21,35 @@ def load_weather_data():
|
||||
# Extrahieren der relevanten Wetterdaten
|
||||
weather_data = []
|
||||
|
||||
for message in data["messages"]:
|
||||
# Jede Nachricht kann mehrere Wetterstationen enthalten
|
||||
if isinstance(message, list):
|
||||
for station_data in message[1:]:
|
||||
station_info = {}
|
||||
# Überprüfe, ob station_data eine Liste ist
|
||||
if isinstance(station_data, list):
|
||||
for info in station_data:
|
||||
# Stelle sicher, dass info ein Dictionary ist
|
||||
if isinstance(info, dict) and "key" in info:
|
||||
if info["key"] == "stationNumber":
|
||||
station_info["stationNumber"] = info["value"]
|
||||
elif info["key"] == "stationOrSiteName":
|
||||
station_info["stationName"] = info["value"]
|
||||
elif info["key"] == "airTemperature":
|
||||
station_info["temperature"] = round(info["value"] - 273.15, 2) # Umwandlung von K in °C
|
||||
elif info["key"] == "windSpeed":
|
||||
station_info["windSpeed"] = info["value"]
|
||||
elif info["key"] == "pressureReducedToMeanSeaLevel":
|
||||
station_info["pressure"] = info["value"]
|
||||
|
||||
# Füge nur Daten hinzu, wenn sie vollständig sind
|
||||
if "stationNumber" in station_info:
|
||||
weather_data.append(station_info)
|
||||
print(json.dumps(entry, indent=2))
|
||||
|
||||
# Überprüfen, ob das "messages"-Feld im JSON vorhanden ist
|
||||
if "messages" in data:
|
||||
for message in data["messages"]:
|
||||
# "message" sollte eine Liste sein, die weitere Listen enthält
|
||||
if isinstance(message, list):
|
||||
for entry in message:
|
||||
# "entry" sollte entweder ein Dictionary oder eine Liste von Daten sein
|
||||
if isinstance(entry, list):
|
||||
station_info = {}
|
||||
for info in entry:
|
||||
# "info" sollte ein Dictionary sein
|
||||
if isinstance(info, dict):
|
||||
if info.get("key") == "stationNumber":
|
||||
station_info["stationNumber"] = info.get("value")
|
||||
elif info.get("key") == "stationOrSiteName":
|
||||
station_info["stationName"] = info.get("value")
|
||||
elif info.get("key") == "airTemperature":
|
||||
# Temperatur von Kelvin in Celsius umwandeln
|
||||
station_info["temperature"] = round(info.get("value") - 273.15, 2)
|
||||
elif info.get("key") == "windSpeed":
|
||||
station_info["windSpeed"] = info.get("value")
|
||||
elif info.get("key") == "pressureReducedToMeanSeaLevel":
|
||||
station_info["pressure"] = info.get("value")
|
||||
|
||||
# Füge nur Stationen mit Stationsnummer hinzu
|
||||
if "stationNumber" in station_info:
|
||||
weather_data.append(station_info)
|
||||
|
||||
# Sortiere nach stationNumber
|
||||
weather_data.sort(key=lambda x: x["stationNumber"])
|
||||
|
||||
Reference in New Issue
Block a user