Frontend weiterarbeit, Client Server datenaustausch und sync, fertiggestellt.

This commit is contained in:
2024-04-19 16:48:23 +02:00
parent 04ad35a91f
commit cd2f302eb1
11 changed files with 228 additions and 112 deletions

View File

@@ -15,65 +15,59 @@ class JsonHandling:
return data["metadata"]["config_has_changed"] == "1"
class DataCollector:
def __init__(self):
self.data = {"timestamps": []}
self.data = {}
self.now = datetime.datetime.now()
def collect_and_store_data(self, producer_values, meter_values, user_values):
print("a")
def collect_and_store_data(self, producer_values, meter_values, user_values, last_data=None):
# Überprüfe, ob die Minute gleich geblieben ist, um Daten zu sammeln
if self.now.minute == datetime.datetime.now().minute:
print("b")
return
self.now = datetime.datetime.now()
print("cccccccc")
# Aktuellen Zeitstempel holen
timestamp = self.now.strftime("%Y-%m-%d %H:%M")
self.data["timestamps"].append(timestamp)
# Werte für Produzenten hinzufügen
for producer_id, values in producer_values.items():
if producer_id not in self.data:
self.data[producer_id] = {}
self.data[producer_id]["values"] = self.update_values(self.data[producer_id].get("values", {}), values)
# Werte für Meter hinzufügen
for meter_id, values in meter_values.items():
if meter_id not in self.data:
self.data[meter_id] = {}
self.data[meter_id]["values"] = self.update_values(self.data[meter_id].get("values", {}), values)
# Werte für Benutzer hinzufügen
for user_id, values in user_values.items():
if user_id not in self.data:
self.data[user_id] = {}
self.data[user_id]["values"] = self.update_values(self.data[user_id].get("values", {}), values)
# Begrenzung der Daten auf die letzten 24 Stunden (1440 Minuten)
if len(self.data["timestamps"]) > 1440:
self.data["timestamps"].pop(0)
for key in self.data.keys():
if key != "timestamps":
for value_key in self.data[key]["values"]:
self.data[key]["values"][value_key].pop(0)
self.data[timestamp] = {
"producer_values": {},
"meter_values": {},
"user_values": {}
}
if os.path.exists("data.json"):
with open("data.json", "r") as file:
existing_data = json.load(file)
existing_data.update(self.data)
self.data = existing_data
# Alle Werte in ein einzelnes Dictionary zusammenführen
all_values = {"producer_values": producer_values, "meter_values": meter_values, "user_values": user_values}
# Alle Werte aktualisieren
for key, values in all_values.items():
self.update_values(self.data[timestamp][key], values)
# Filtere Werte basierend auf dem letzten mitgegebenen Zeitstempel
if last_data:
# Konvertiere den letzten Zeitstempel in ein datetime-Objekt
last_data = datetime.datetime.strptime(last_data, "%Y-%m-%d %H:%M")
# Entferne alle Einträge in self.data, die vor dem letzten Zeitstempel liegen
self.data = {ts: values for ts, values in self.data.items() if datetime.datetime.strptime(ts, "%Y-%m-%d %H:%M") > last_data}
# Begrenze die Daten auf die letzten 24 Stunden (1440 Minuten)
timestamps_sorted = sorted(self.data.keys(), reverse=True)
if len(timestamps_sorted) > 1440:
timestamps_to_remove = timestamps_sorted[1440:]
for timestamp_to_remove in timestamps_to_remove:
del self.data[timestamp_to_remove]
# Daten als JSON speichern
with open("data.json", "w") as file:
json.dump(self.data, file)
def update_values(self, current_values, new_values):
for key, value in new_values.items():
if key not in current_values:
current_values[key] = []
current_values[key].append(value)
return current_values
current_values[key] = value
else:
# Überprüfen, ob der Wert bereits eine Liste ist
if not isinstance(current_values[key], list):
# Wenn nicht, konvertieren Sie ihn in eine Liste
current_values[key] = [current_values[key]]
# Füge den neuen Wert der Liste hinzu
current_values[key].append(value)

View File

@@ -1 +1 @@
{"timestamps": ["2024-04-18 17:18", "2024-04-18 17:19", "2024-04-18 17:20", "2024-04-18 17:21", "2024-04-18 17:22", "2024-04-18 17:23", "2024-04-18 17:24"], "Producer_sum": {"values": {"success": [true, true, true, true, true, true, true], "day_energy": [35718, 35866, 35991, 36109, 36236, 36329, 36438], "pac": [7995, 8083, 7758, 7083, 6439, 6084, 5755], "total_energy": [59811200, 59811300, 59811400, 59811604, 59811604, 59811804, 59811902], "year_energy": [8725390, 8725539, 8725663, 8725781, 8725906, 8725999, 8726110]}}, "Fronius_15kW": {"values": {"success": [true, true, true, true, true, true, true], "day_energy": [17347, 17409, 17461, 17512, 17564, 17603, 17649], "pac": [3359, 3388, 3251, 2959, 2688, 2538, 2393], "total_energy": [31330000, 31330100, 31330100, 31330202, 31330202, 31330302, 31330302], "year_energy": [3532817, 3532880, 3532932, 3532982, 3533033, 3533072, 3533119]}}, "Fronius_20kW": {"values": {"success": [true, true, true, true, true, true, true], "day_energy": [18371, 18457, 18530, 18597, 18672, 18726, 18789], "pac": [4636, 4695, 4507, 4124, 3751, 3546, 3362], "total_energy": [28481200, 28481200, 28481300, 28481402, 28481402, 28481502, 28481600], "year_energy": [5192573, 5192659, 5192731, 5192799, 5192873, 5192927, 5192991]}}, "Meter_Sum": {"values": {"success": [true, true, true, true, true, true, true], "Current_AC_Phase_1": [5, 4.45, 6.4, 7.25, 11.2, 6.3, 9], "Current_AC_Phase_2": [5.75, 5.45, 6.5, 7.5, 7.5, 2.714, 2.175], "Current_AC_Phase_3": [-4.55, -4.6, -4.3, -3.9, 7.55, 4.4, 4.7], "PowerReal_P_Sum": [443, 200.8, 1714.5, 1879.3, 5569.2, 2260.1, 3062.9]}}, "Meter_Fronius": {"values": {"success": [true, true, true, true, true, true, true], "Current_AC_Phase_1": [5, 4.45, 6.4, 7.25, 11.2, 6.3, 9], "Current_AC_Phase_2": [5.75, 5.45, 6.5, 7.5, 7.5, 2.714, 2.175], "Current_AC_Phase_3": [-4.55, -4.6, -4.3, -3.9, 7.55, 4.4, 4.7], "PowerReal_P_Sum": [443, 200.8, 1714.5, 1879.3, 5569.2, 2260.1, 3062.9]}}, "User_data": {"values": {"Current_Power": [0, 0, 0, 0, 0, 0, 0], "Used_Energy": [0, 0, 0, 0, 0, 0, 0], "Current_Prio": [0, 0, 0, 0, 0, 0, 0], "Current_deltaPower": [0, 0, 0, 0, 0, 0, 0], "measured_Temp": [0, 0, 0, 0, 0, 0, 0]}}, "Umod1": {"values": {"Current_Power": [0, 0, 0, 0, 0, 0, 0], "Used_Energy": [6, 6, 6, 6, 6, 6, 6], "Current_Prio": [1, 1, 1, 1, 1, 1, 1], "Current_deltaPower": [0, 0, 0, 0, 0, 0, 0], "measured_Temp": [0, 0, 0, 0, 0, 0, 0]}}, "Umod3": {"values": {"Current_Power": [0, 0, 0, 0, 0, 0, 0], "Used_Energy": [6, 6, 6, 6, 6, 6, 6], "Current_Prio": [3, 3, 3, 3, 3, 3, 3], "Current_deltaPower": [0, 0, 0, 0, 0, 0, 0], "measured_Temp": [0, 0, 0, 0, 0, 0, 0]}}, "Umod2.0": {"values": {"Current_Power": [0, 0, 0, 0, 0, 0, 0], "Used_Energy": [6, 6, 6, 6, 6, 6, 6], "Current_Prio": [2, 2, 2, 2, 2, 2, 2], "Current_deltaPower": [0, 0, 0, 0, 0, 0, 0], "measured_Temp": [0, 0, 0, 0, 0, 0, 0]}}, "Umod2.1": {"values": {"Current_Power": [0, 0, 0, 0, 0, 0, 0], "Used_Energy": [6, 6, 6, 6, 6, 6, 6], "Current_Prio": [2, 2, 2, 2, 2, 2, 2], "Current_deltaPower": [0, 0, 0, 0, 0, 0, 0], "measured_Temp": [0, 0, 0, 0, 0, 0, 0]}}, "Umod2.2": {"values": {"Current_Power": [0, 0, 0, 0, 0, 0, 0], "Used_Energy": [6, 6, 6, 6, 6, 6, 6], "Current_Prio": [2, 2, 2, 2, 2, 2, 2], "Current_deltaPower": [0, 0, 0, 0, 0, 0, 0], "measured_Temp": [0, 0, 0, 0, 0, 0, 0]}}, "Umod2.3": {"values": {"Current_Power": [0, 0, 0, 0, 0, 0, 0], "Used_Energy": [6, 6, 6, 6, 6, 6, 6], "Current_Prio": [2, 2, 2, 2, 2, 2, 2], "Current_deltaPower": [0, 0, 0, 0, 0, 0, 0], "measured_Temp": [0, 0, 0, 0, 0, 0, 0]}}, "Usta2.0": {"values": {"Current_Power": [0, 0, 0, 0, 0, 0, 0], "Used_Energy": [4, 4, 4, 4, 4, 4, 4], "Current_Prio": [2, 2, 2, 2, 2, 2, 2], "Current_deltaPower": [0, 0, 0, 0, 0, 0, 0], "measured_Temp": [0, 0, 0, 0, 0, 0, 0]}}, "shelly_Boiler": {"values": {"Current_Power": [0, 0, 0, 0, 0, 0, 0], "Used_Energy": [0, 0, 0, 0, 0, 0, 0], "Current_Prio": [2, 2, 2, 2, 2, 2, 2], "Current_deltaPower": [0, 0, 0, 0, 0, 0, 0], "measured_Temp": [20.56, 20.56, 20.56, 20.56, 20.56, 20.56, 20.56]}}}
{"2024-04-19 16:47": {"producer_values": {"Producer_sum": {"success": true, "day_energy": 94190, "pac": 7661, "total_energy": 59918400, "year_energy": 8832601}, "Fronius_15kW": {"success": true, "day_energy": 38010, "pac": 3060, "total_energy": 31373402, "year_energy": 3576175}, "Fronius_20kW": {"success": true, "day_energy": 56180, "pac": 4601, "total_energy": 28544998, "year_energy": 5256426}}, "meter_values": {"Meter_Sum": {"success": true, "Current_AC_Phase_1": 17.65, "Current_AC_Phase_2": 25.9, "Current_AC_Phase_3": 22.3, "PowerReal_P_Sum": 15015.1}, "Meter_Fronius": {"success": true, "Current_AC_Phase_1": 17.65, "Current_AC_Phase_2": 25.9, "Current_AC_Phase_3": 22.3, "PowerReal_P_Sum": 15015.1}}, "user_values": {"User_data": {"Current_Power": 0, "Used_Energy": 0, "Current_Prio": 0, "Current_deltaPower": 0, "measured_Temp": 0}, "Umod1": {"Current_Power": 0, "Used_Energy": 6, "Current_Prio": 1, "Current_deltaPower": 0, "measured_Temp": 0}, "Umod3": {"Current_Power": 0, "Used_Energy": 6, "Current_Prio": 3, "Current_deltaPower": 0, "measured_Temp": 0}, "Umod2.0": {"Current_Power": 0, "Used_Energy": 6, "Current_Prio": 2, "Current_deltaPower": 0, "measured_Temp": 0}, "Umod2.1": {"Current_Power": 0, "Used_Energy": 6, "Current_Prio": 2, "Current_deltaPower": 0, "measured_Temp": 0}, "Umod2.2": {"Current_Power": 0, "Used_Energy": 6, "Current_Prio": 2, "Current_deltaPower": 0, "measured_Temp": 0}, "Umod2.3": {"Current_Power": 0, "Used_Energy": 6, "Current_Prio": 2, "Current_deltaPower": 0, "measured_Temp": 0}, "Usta2.0": {"Current_Power": 0, "Used_Energy": 4, "Current_Prio": 2, "Current_deltaPower": 0, "measured_Temp": 0}, "shelly_Boiler": {"Current_Power": 0, "Used_Energy": 0, "Current_Prio": 2, "Current_deltaPower": 0, "measured_Temp": 21.69}}}}

View File

@@ -31,7 +31,16 @@ def calcSomeStuff():
while True:
# Neue Konfig holen
config = json.dumps(serverrequests.get_config(ID))
try:
config = json.dumps(serverrequests.get_config(ID))
# Versuche, das JSON zu laden
except:
# Falls ein Fehler auftritt oder kein JSON zurückkommt, lade config.json
with open('config.json', 'r') as file:
config = json.dumps(json.load(file))
if JsonHandling.JsonHandling.check_config_has_changed(config):
producers = energyproducer.EnergyProducer.create_producerlist_from_json(config)
@@ -48,10 +57,17 @@ while True:
main.EnergyUserFactory.distribute_energy(users, -1*(meter_values["Meter_Sum"]["PowerReal_P_Sum"]))
user_values = energyuser.EnergyUser.get_all_current_values(users)
Collector.collect_and_store_data(producer_values, meter_values, user_values)
try:
a = json.loads(config)['last_timestamp']
except:
a = "1970-01-01 00:00"
Collector.collect_and_store_data(producer_values, meter_values, user_values, a)
data = Collector.data
serverrequests.set_data(ID, data)
try:
if next(iter(data)) != a:
serverrequests.set_data(ID, data)
except:
pass
time.sleep(5)