Frontend weiterarbeit, Client Server datenaustausch und sync, fertiggestellt.
This commit is contained in:
@@ -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)
|
||||
Binary file not shown.
Binary file not shown.
Binary file not shown.
@@ -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}}}}
|
||||
@@ -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)
|
||||
Reference in New Issue
Block a user