From ab3e04ab57992f3c9a25df9a41af2e2a04b0981c Mon Sep 17 00:00:00 2001 From: Juul Date: Wed, 23 Jul 2025 22:27:40 +0200 Subject: [PATCH] bugfixes --- .gitignore | 4 ++- Telegram/Telegram.py | 75 +++++++++++++++++++------------------- Telegram/TelegramUtil.py | 14 ++++---- Voorbeelden/Ontvang.txt | 77 ++++++++++++++++++++++++++++++++++++++++ Voorbeelden/Verzend.txt | 0 __main__.py | 6 ++-- 6 files changed, 129 insertions(+), 47 deletions(-) create mode 100644 Voorbeelden/Ontvang.txt create mode 100644 Voorbeelden/Verzend.txt diff --git a/.gitignore b/.gitignore index 208a4b7..6197c3b 100644 --- a/.gitignore +++ b/.gitignore @@ -5,4 +5,6 @@ build/* dist/* *.pyz -*.spec \ No newline at end of file +*.spec + +Voorbeelden/Verzend.txt \ No newline at end of file diff --git a/Telegram/Telegram.py b/Telegram/Telegram.py index 0dbb809..f31a970 100644 --- a/Telegram/Telegram.py +++ b/Telegram/Telegram.py @@ -47,47 +47,48 @@ class Telegram: def berekenCrc(self, telegram): bericht = b''.join(telegram) crc = binascii.crc_hqx(bericht, 0x0000) - return f'!{crc:04X}\r\n' + return f'!{crc:04X}\r\n'.encode() def maakTelegram(self): return [ - f'{TelegramData.P1_KENMERK}\r\n'.encode(), + f'\x00'.encode(), + f'{TelegramData.P1_KENMERK.value}\r\n'.encode(), f'\r\n'.encode(), - f'{TelegramData.FIRMWARE_VERSIE}(50)\r\n'.encode(), - f'{TelegramData.DATUM_TIJD}({self.getDatumTijd()})\r\n'.encode(), - f'{TelegramData.METER_ID}({self.meterId})\r\n'.encode(), - f'{TelegramData.TOTAAL_VERBRUIK_TARIEF1}({self.totaalVerbruikTarief1})\r\n'.encode(), - f'{TelegramData.TOTAAL_VERBRUIK_TARIEF2}({self.totaalVerbruikTarief2})\r\n'.encode(), - f'{TelegramData.TOTAAL_TERUGLEVERING_TARIEF1}({self.totaalTerugleveringTarief1})\r\n'.encode(), - f'{TelegramData.TOTAAL_TERUGLEVERING_TARIEF2}({self.totaalTerugleveringTarief2})\r\n'.encode(), - f'{TelegramData.TARIEF_INDICATOR}({self.tariefIndicator})\r\n'.encode(), - f'{TelegramData.ACTUEEL_VERBRUIK}({self.actueelVerbruik})\r\n'.encode(), - f'{TelegramData.ACTUEELE_TERUGLEVERING}({self.actueleTeruglevering})\r\n'.encode(), - f'{TelegramData.STATUSCODE2}({self.statuscode2})\r\n'.encode(), - f'{TelegramData.STATUSCODE1}({self.statuscode1})\r\n'.encode(), - f'{TelegramData.ONDERBREKINGSLOG}({self.onderbrekingslog})\r\n'.encode(), - f'{TelegramData.TELLER_ELEKTRICITEITSMETERSTAND1}({self.tellerElektriciteitsMeterstand1})\r\n'.encode(), - f'{TelegramData.TELLER_ELEKTRICITEITSMETERSTAND2}({self.tellerElektriciteitsMeterstand2})\r\n'.encode(), - f'{TelegramData.TELLER_ELEKTRICITEITSMETERSTAND3}({self.tellerElektriciteitsMeterstand3})\r\n'.encode(), - f'{TelegramData.SPANNINGSONDERBREKINGEN_fASE1}({self.spanningsOnderbrekingenFase1})\r\n'.encode(), - f'{TelegramData.SPANNINGSONDERBREKINGEN_fASE2}({self.spanningsOnderbrekingenFase2})\r\n'.encode(), - f'{TelegramData.SPANNINGSONDERBREKINGEN_fASE3}({self.spanningsOnderbrekingenFase3})\r\n'.encode(), - f'{TelegramData.BEPAALDE_EVENTS}({self.bepaaldeEvents})\r\n'.encode(), - f'{TelegramData.SPANNING_FASE1}({self.spanningFase1})\r\n'.encode(), - f'{TelegramData.SPANNING_FASE2}({self.spanningFase2})\r\n'.encode(), - f'{TelegramData.SPANNING_FASE3}({self.spanningFase3})\r\n'.encode(), - f'{TelegramData.STROOM_FASE1}({self.stroomFase1})\r\n'.encode(), - f'{TelegramData.STROOM_FASE2}({self.stroomFase2})\r\n'.encode(), - f'{TelegramData.STROOM_FASE3}({self.stroomFase3})\r\n'.encode(), - f'{TelegramData.VERMOGEN_FASE_1}({self.vermogenFase1})\r\n'.encode(), - f'{TelegramData.VERMOGEN_FASE_2}({self.vermogenFase2})\r\n'.encode(), - f'{TelegramData.VERMOGEN_FASE_3}({self.vermogenFase3})\r\n'.encode(), - f'{TelegramData.TERUGLEVERING_FASE1}({self.terugleveringFase1})\r\n'.encode(), - f'{TelegramData.TERUGLEVERING_FASE2}({self.terugleveringFase2})\r\n'.encode(), - f'{TelegramData.TERUGLEVERING_FASE3}({self.terugleveringFase3})\r\n'.encode(), - f'{TelegramData.GASMETER_TELEGRAM}({self.gasmeterTelegram})\r\n'.encode(), - f'{TelegramData.GASMETER_ID}({self.gasmeterId})\r\n'.encode(), - f'{TelegramData.GASVERBRUIK}({self.gasverbruik})\r\n'.encode(), + f'{TelegramData.FIRMWARE_VERSIE.value}(50)\r\n'.encode(), + f'{TelegramData.DATUM_TIJD.value}({self.getDatumTijd()})\r\n'.encode(), + f'{TelegramData.METER_ID.value}({self.meterId})\r\n'.encode(), + f'{TelegramData.TOTAAL_VERBRUIK_TARIEF1.value}({self.totaalVerbruikTarief1})\r\n'.encode(), + f'{TelegramData.TOTAAL_VERBRUIK_TARIEF2.value}({self.totaalVerbruikTarief2})\r\n'.encode(), + f'{TelegramData.TOTAAL_TERUGLEVERING_TARIEF1.value}({self.totaalTerugleveringTarief1})\r\n'.encode(), + f'{TelegramData.TOTAAL_TERUGLEVERING_TARIEF2.value}({self.totaalTerugleveringTarief2})\r\n'.encode(), + f'{TelegramData.TARIEF_INDICATOR.value}({self.tariefIndicator})\r\n'.encode(), + f'{TelegramData.ACTUEEL_VERBRUIK.value}({self.actueelVerbruik})\r\n'.encode(), + f'{TelegramData.ACTUEELE_TERUGLEVERING.value}({self.actueleTeruglevering})\r\n'.encode(), + f'{TelegramData.STATUSCODE2.value}({self.statuscode2})\r\n'.encode(), + f'{TelegramData.STATUSCODE1.value}({self.statuscode1})\r\n'.encode(), + f'{TelegramData.ONDERBREKINGSLOG.value}({self.onderbrekingslog})\r\n'.encode(), + f'{TelegramData.TELLER_ELEKTRICITEITSMETERSTAND1.value}({self.tellerElektriciteitsMeterstand1})\r\n'.encode(), + f'{TelegramData.TELLER_ELEKTRICITEITSMETERSTAND2.value}({self.tellerElektriciteitsMeterstand2})\r\n'.encode(), + f'{TelegramData.TELLER_ELEKTRICITEITSMETERSTAND3.value}({self.tellerElektriciteitsMeterstand3})\r\n'.encode(), + f'{TelegramData.SPANNINGSONDERBREKINGEN_fASE1.value}({self.spanningsOnderbrekingenFase1})\r\n'.encode(), + f'{TelegramData.SPANNINGSONDERBREKINGEN_fASE2.value}({self.spanningsOnderbrekingenFase2})\r\n'.encode(), + f'{TelegramData.SPANNINGSONDERBREKINGEN_fASE3.value}({self.spanningsOnderbrekingenFase3})\r\n'.encode(), + f'{TelegramData.BEPAALDE_EVENTS.value}({self.bepaaldeEvents})\r\n'.encode(), + f'{TelegramData.SPANNING_FASE1.value}({self.spanningFase1})\r\n'.encode(), + f'{TelegramData.SPANNING_FASE2.value}({self.spanningFase2})\r\n'.encode(), + f'{TelegramData.SPANNING_FASE3.value}({self.spanningFase3})\r\n'.encode(), + f'{TelegramData.STROOM_FASE1.value}({self.stroomFase1})\r\n'.encode(), + f'{TelegramData.STROOM_FASE2.value}({self.stroomFase2})\r\n'.encode(), + f'{TelegramData.STROOM_FASE3.value}({self.stroomFase3})\r\n'.encode(), + f'{TelegramData.VERMOGEN_FASE_1.value}({self.vermogenFase1})\r\n'.encode(), + f'{TelegramData.VERMOGEN_FASE_2.value}({self.vermogenFase2})\r\n'.encode(), + f'{TelegramData.VERMOGEN_FASE_3.value}({self.vermogenFase3})\r\n'.encode(), + f'{TelegramData.TERUGLEVERING_FASE1.value}({self.terugleveringFase1})\r\n'.encode(), + f'{TelegramData.TERUGLEVERING_FASE2.value}({self.terugleveringFase2})\r\n'.encode(), + f'{TelegramData.TERUGLEVERING_FASE3.value}({self.terugleveringFase3})\r\n'.encode(), + f'{TelegramData.GASMETER_TELEGRAM.value}({self.gasmeterTelegram})\r\n'.encode(), + f'{TelegramData.GASMETER_ID.value}({self.gasmeterId})\r\n'.encode(), + f'{TelegramData.GASVERBRUIK.value}({self.gasverbruik})\r\n'.encode(), ] def __str__(self): diff --git a/Telegram/TelegramUtil.py b/Telegram/TelegramUtil.py index ec937ce..c45735a 100644 --- a/Telegram/TelegramUtil.py +++ b/Telegram/TelegramUtil.py @@ -2,18 +2,18 @@ from time import sleep import serial -INPUT_PORT = '/dev/ttyUSB0' +INPUT_PORT = '/dev/ttyUSB1' OUTPUT_PORT = '/dev/ttyUSB0' -# dataInput = serial.Serial(INPUT_PORT, 115200, timeout=1) -# dataOutput = serial.Serial(OUTPUT_PORT, 115200, timeout=1) +dataInput = serial.Serial(INPUT_PORT, 115200, timeout=1) +dataOutput = serial.Serial(OUTPUT_PORT, 115200, timeout=1) -# def lees(): -# line = dataInput.readline() -# print(line) +def lees(): + line = dataInput.readline() + dataOutput.write(line) def verzend(telegram): for line in telegram: print(line) - # dataOutput.write(line) + dataOutput.write(line) sleep(1) diff --git a/Voorbeelden/Ontvang.txt b/Voorbeelden/Ontvang.txt new file mode 100644 index 0000000..6c3d98c --- /dev/null +++ b/Voorbeelden/Ontvang.txt @@ -0,0 +1,77 @@ +b'\x00\x00/CTA5ZIV-METER\r\n' +b'\r\n' +b'1-3:0.2.8(50)\r\n' +b'0-0:1.0.0(250723212950S)\r\n' +b'0-0:96.1.1(4530303737303030373330383837373232)\r\n' +b'1-0:1.8.1(015903.376*kWh)\r\n' +b'1-0:1.8.2(003692.715*kWh)\r\n' +b'1-0:2.8.1(002268.443*kWh)\r\n' +b'1-0:2.8.2(005778.535*kWh)\r\n' +b'0-0:96.14.0(0001)\r\n' +b'1-0:1.7.0(00.468*kW)\r\n' +b'1-0:2.7.0(00.000*kW)\r\n' +b'0-0:96.7.21(00009)\r\n' +b'0-0:96.7.9(00003)\r\n' +b'1-0:99.97.0(1)(0-0:96.7.19)(240624104032S)(0000000215*s)\r\n' +b'1-0:32.32.0(00000)\r\n' +b'1-0:52.32.0(00000)\r\n' +b'1-0:72.32.0(00000)\r\n' +b'1-0:32.36.0(00005)\r\n' +b'1-0:52.36.0(00002)\r\n' +b'1-0:72.36.0(00003)\r\n' +b'0-0:96.13.0()\r\n' +b'1-0:32.7.0(231.0*V)\r\n' +b'1-0:52.7.0(232.0*V)\r\n' +b'1-0:72.7.0(233.0*V)\r\n' +b'1-0:31.7.0(001*A)\r\n' +b'1-0:51.7.0(000*A)\r\n' +b'1-0:71.7.0(000*A)\r\n' +b'1-0:21.7.0(00.262*kW)\r\n' +b'1-0:41.7.0(00.110*kW)\r\n' +b'1-0:61.7.0(00.089*kW)\r\n' +b'1-0:22.7.0(00.000*kW)\r\n' +b'1-0:42.7.0(00.000*kW)\r\n' +b'1-0:62.7.0(00.000*kW)\r\n' +b'0-2:24.1.0(003)\r\n' +b'0-2:96.1.0(4730303732303034323030333530343232)\r\n' +b'0-2:24.2.1(250723212500S)(02381.097*m3)\r\n' +b'!BE3F\r\n' +b'\x00' +b'/CTA5ZIV-METER\r\n' +b'\r\n' +b'1-3:0.2.8(50)\r\n' +b'0-0:1.0.0(250723212951S)\r\n' +b'0-0:96.1.1(4530303737303030373330383837373232)\r\n' +b'1-0:1.8.1(015903.377*kWh)\r\n' +b'1-0:1.8.2(003692.715*kWh)\r\n' +b'1-0:2.8.1(002268.443*kWh)\r\n' +b'1-0:2.8.2(005778.535*kWh)\r\n' +b'0-0:96.14.0(0001)\r\n' +b'1-0:1.7.0(00.461*kW)\r\n' +b'1-0:2.7.0(00.000*kW)\r\n' +b'0-0:96.7.21(00009)\r\n' +b'0-0:96.7.9(00003)\r\n' +b'1-0:99.97.0(1)(0-0:96.7.19)(240624104032S)(0000000215*s)\r\n' +b'1-0:32.32.0(00000)\r\n' +b'1-0:52.32.0(00000)\r\n' +b'1-0:72.32.0(00000)\r\n' +b'1-0:32.36.0(00005)\r\n' +b'1-0:52.36.0(00002)\r\n' +b'1-0:72.36.0(00003)\r\n' +b'0-0:96.13.0()\r\n' +b'1-0:32.7.0(231.0*V)\r\n' +b'1-0:52.7.0(231.0*V)\r\n' +b'1-0:72.7.0(232.0*V)\r\n' +b'1-0:31.7.0(001*A)\r\n' +b'1-0:51.7.0(000*A)\r\n' +b'1-0:71.7.0(000*A)\r\n' +b'1-0:21.7.0(00.261*kW)\r\n' +b'1-0:41.7.0(00.109*kW)\r\n' +b'1-0:61.7.0(00.090*kW)\r\n' +b'1-0:22.7.0(00.000*kW)\r\n' +b'1-0:42.7.0(00.000*kW)\r\n' +b'1-0:62.7.0(00.000*kW)\r\n' +b'0-2:24.1.0(003)\r\n' +b'0-2:96.1.0(4730303732303034323030333530343232)\r\n' +b'0-2:24.2.1(250723212500S)(02381.097*m3)\r\n' +b'!F2A0\r\n' \ No newline at end of file diff --git a/Voorbeelden/Verzend.txt b/Voorbeelden/Verzend.txt new file mode 100644 index 0000000..e69de29 diff --git a/__main__.py b/__main__.py index 42e5b3a..62cff3f 100644 --- a/__main__.py +++ b/__main__.py @@ -1,7 +1,9 @@ from Telegram.Telegram import Telegram -from Telegram.TelegramUtil import verzend +from Telegram.TelegramData import TelegramData +from Telegram.TelegramUtil import verzend, lees if __name__ == '__main__': telegram = Telegram() while True: - verzend(telegram.__str__()) \ No newline at end of file + lees() + # verzend(telegram.__str__()) \ No newline at end of file