EOS/server_load_profile.py

55 lines
1.9 KiB
Python
Raw Normal View History

2024-02-16 15:27:56 +01:00
from flask import Flask, jsonify, request
import numpy as np
from datetime import datetime
app = Flask(__name__)
# Lade die .npz-Datei beim Start der Anwendung
data = np.load('load_profiles.npz')
load_profiles_exp = data["yearly_profiles"] #.flatten().tolist()
load_profiles_std = data["yearly_profiles_std"] #.flatten().tolist()
print(load_profiles_exp)
print(load_profiles_exp.shape)
#load_profiles_exp = load_profiles_exp*1000.0
print(load_profiles_exp)
print(load_profiles_exp.sum())
@app.route('/getdata', methods=['GET'])
def get_data():
# Hole das Datum aus den Query-Parametern
date_str = request.args.get('date')
year_energy = request.args.get('year_energy')
try:
# Konvertiere das Datum in ein datetime-Objekt
date_obj = datetime.strptime(date_str, '%Y-%m-%d')
year_energy = float(year_energy)
load_profiles_exp_l = load_profiles_exp*year_energy
load_profiles_std_l = load_profiles_std*year_energy
# Berechne den Tag des Jahres
day_of_year = date_obj.timetuple().tm_yday
# Konvertiere den Tag des Jahres in einen String, falls die Schlüssel als Strings gespeichert sind
day_key = int(day_of_year)
#print(day_key)
# Überprüfe, ob der Tag im Jahr in den Daten vorhanden ist
if day_key < len(load_profiles_exp):
# Konvertiere das Array in eine Liste für die JSON-Antwort
array_list = ((load_profiles_exp_l[day_key]).tolist(),(load_profiles_std_l)[day_key].tolist())
return jsonify({date_str: array_list})
else:
return jsonify({"error": "Datum nicht gefunden"}), 404
except ValueError:
# Wenn das Datum nicht im richtigen Format ist oder ungültig ist
return jsonify({"error": "Ungültiges Datum"}), 400
if __name__ == '__main__':
app.run(debug=True)