NEWS
GoodWe Wechselrichter und ioBroker
-
Nochmal Danke.
Habe in allinone.py folgende Zeile eingefügt, "print(f"{gw.data}")" und bekomme auf dem Bildschirm die Ausgabe des Inhaltes von "gw.data".
Wie bekomme ich den kompletten Inhalt von "gw.data" nach ioBroker?
MfG
Wastl -
Hallo,
Danke für das tolle Script + Anleitung! Läuft 1A bei mir.
Leider ist das Sems Portal dann schwer mit dem Handy erreichbar und sehr träge trotz 60sec timeout.
Hab nun endlich einen LAN Dongle und würde gerne per Modbus TCP mit dem IoBroker auslesen. Hast du bzw. jemand hier Erfahrung damit ?
Modbus Verbindung steht schon mal, leider bekomme ich noch keine Werte in meine Register.Gruß
-
Hallo,
Danke für das tolle Script + Anleitung! Läuft 1A bei mir.
Leider ist das Sems Portal dann schwer mit dem Handy erreichbar und sehr träge trotz 60sec timeout.
Hab nun endlich einen LAN Dongle und würde gerne per Modbus TCP mit dem IoBroker auslesen. Hast du bzw. jemand hier Erfahrung damit ?
Modbus Verbindung steht schon mal, leider bekomme ich noch keine Werte in meine Register.Gruß
@xreactz ich habe von Anfang an das LAN Dongle.
Als Tipp vorab! Trage eine statische IP ein. Bei DHCP verliert das LAN Dongle die Verbindung.
Mir ist nicht bekannt, dass GoodWe und Modbus TCP funktionieren. Wenn du da weiter kommst, dann berichte gerne mal hier.
-
@xreactz ich habe von Anfang an das LAN Dongle.
Als Tipp vorab! Trage eine statische IP ein. Bei DHCP verliert das LAN Dongle die Verbindung.
Mir ist nicht bekannt, dass GoodWe und Modbus TCP funktionieren. Wenn du da weiter kommst, dann berichte gerne mal hier.
Kurze Rückmeldung betreffend meiner Anfrage "Anbindung mittel Modbus", hab nun einen Stabile Verbindung mittels Modbus zum Wechselrichter:+1:
Anbindung mittels Modbus TCP am Goodwe Wechselrichter ist mit der Lan Box also möglich. Wichtig ist das keine Aliases benutzt werden dürfen!

Gruß
-
Kurze Rückmeldung betreffend meiner Anfrage "Anbindung mittel Modbus", hab nun einen Stabile Verbindung mittels Modbus zum Wechselrichter:+1:
Anbindung mittels Modbus TCP am Goodwe Wechselrichter ist mit der Lan Box also möglich. Wichtig ist das keine Aliases benutzt werden dürfen!

Gruß
-
Hallo zusammen,
da man im Netz nichts findet, wie man ein GoodWe Wechselrichter abfragen und in ioBroker verwalten kann, schreibe ich hier ein kleines HowTo, da es kein Adapter dafür gibt.
Ich gehe davon aus, dass Ihr bereits ein Account im SEMS Portal habt. Vom SEMS Portal kommen nämlich die Daten.
HowTo:
- pygoodwe installieren:
sudo pip3 install pygoodwe- Danach holt Ihr euch den Source Code "pygoodwe" von yaleman aus Github:
wget https://github.com/yaleman/pygoodwe/archive/master.zip unzip master.zip cd pygoodwe-master- Die Zugangsdaten vom SEMS Portal trägt Ihr nun in der config.py ein:
mv config.py.example config.py- Werte vom GoodWe Wechselrichter abfragen:
./allinone.py#!/usr/bin/env python3 import json from config import args from pygoodwe import SingleInverter, API #print("Single Inverter") gw = SingleInverter( system_id=args.get('gw_station_id', '1'), account=args.get('gw_account', 'thiswillnotwork'), password=args.get('gw_password', 'thiswillnotwork'), ) # print("Grabbing data") gw.getCurrentReadings() # Ausgabe PV Anlage print(json.dumps(gw.data.get('inverter').get('out_pac'), indent=2)) pvdata = gw.data.get('inverter',{}).get('out_pac',"") # Batterie in % socdata = gw.data.get('inverter',{}).get('soc',) if socdata: print("{}".format(socdata)) # Batterie Ladestatus print(json.dumps(gw.data.get('inverter').get('battery_power'), )) batterydata = gw.data.get('inverter',{}).get('battery_power',) # Stromlast vom Haus print(f"{gw.getLoadFlow()}") # Strom ins Stromnetz print(f"{gw.getPmeter()}") # Strom Produktion Heute print(json.dumps(gw.data.get('inverter').get('eday'), indent=2)) # Strom Produktion Gesamt print(json.dumps(gw.data.get('inverter').get('etotal'), indent=2))Ihr könnt beliebig viele Werte Abfragen und ins Script rein werfen und erweitern. Für mich sind das die wichtigsten Werte.
- Die Abgefragten Werte müssen in ioBroker rein:
Dafür habe ich ein javascript Script, welches in ioBroker ausgeführt wird.
exec('/home/pi/pygoodwe-master/allinone.py', function (error, stdout, stderr) { if(error) log('Fehler Python: ' + stderr, 'warn'); else if(stdout) { let arr = stdout.split('\n'); setState('Datenpunkte.0.PV-Anlage.PV-Power', arr[0], true); setState('Datenpunkte.0.PV-Anlage.PV_Batterie_Status', arr[1], true); setState('Datenpunkte.0.PV-Anlage.PV_Batterie_Ladung', arr[2], true); setState('Datenpunkte.0.PV-Anlage.PV_Haus_Last', arr[3], true); setState('Datenpunkte.0.PV-Anlage.PV_Strom_zu_Stadtwerken', arr[4], true); setState('Datenpunkte.0.PV-Anlage.PV_Strom_Heute', arr[5], true); setState('Datenpunkte.0.PV-Anlage.PV_Strom_Gesamt', arr[6], true); } });Die Datenpunkte müsst Ihr vorher anlegen. Bei ausführen des Scriptes müssten alle werte in den jeweiligen Datenpunkten drin sein.
Damit dies auch aktualisiert wird, habe ich mit Blockly ein Zeitplan erstellt, der das Script alle 2 Minuten ausführt.
schedule("*/2 * * * *", function () { setState("javascript.0.scriptEnabled.PV_Anlage.Skript_1"/*scriptEnabled.PV_Anlage.Skript_1*/, true); setStateDelayed("javascript.0.scriptEnabled.PV_Anlage.Skript_1"/*scriptEnabled.PV_Anlage.Skript_1*/, false, 50000, false); });Damit habt Ihr nun alle Werte in ioBroker :-)
Meine Visualisierung sieht dann so aus:

Viel Spaß damit!
@jb1985 Vielen Dank für Deine Beschreibung. Top. Ich war tagelang happy. Nun bekomme ich plötzlich immer folgende Meldung. Kannst Du mir helfen?
ERROR:root:RequestException: 403 Client Error: Forbidden for url: https://semsportal.com/api/v1/PowerStation/GetMonitorDetailByPowerstationId
ERROR:root:RequestException: 403 Client Error: Forbidden for url: https://semsportal.com/api/v1/PowerStation/GetMonitorDetailByPowerstationId
ERROR:root:Failed to call GoodWe API url='https://semsportal.com/api/v1/PowerStation/GetMonitorDetailByPowerstationId'
ERROR:root:no inverter data, try True, trying again in 30 seconds
ERROR:root:RequestException: 403 Client Error: Forbidden for url: https://semsportal.com/api/v1/PowerStation/GetMonitorDetailByPowerstationId
ERROR:root:RequestException: 403 Client Error: Forbidden for url: https://semsportal.com/api/v1/PowerStation/GetMonitorDetailByPowerstationId
ERROR:root:Failed to call GoodWe API url='https://semsportal.com/api/v1/PowerStation/GetMonitorDetailByPowerstationId'
Traceback (most recent call last):
File "/home/pi/pygoodwe-master/allinone.py", line 8, in <module>
gw = SingleInverter(
File "/home/pi/pygoodwe-master/pygoodwe/init.py", line 446, in init
super().init(system_id, account, password, **kwargs)
File "/home/pi/pygoodwe-master/pygoodwe/init.py", line 60, in init
self.getCurrentReadings(raw=True)
File "/home/pi/pygoodwe-master/pygoodwe/init.py", line 456, in getCurrentReadings
super().getCurrentReadings(self, raw)
File "/home/pi/pygoodwe-master/pygoodwe/init.py", line 98, in getCurrentReadings
retval = self.getCurrentReadings(
File "/home/pi/pygoodwe-master/pygoodwe/init.py", line 456, in getCurrentReadings
super().getCurrentReadings(self, raw)
File "/home/pi/pygoodwe-master/pygoodwe/init.py", line 93, in getCurrentReadings
if retry < maxretries:
TypeError: '<' not supported between instances of 'SingleInverter' and 'int' -
@jb1985 Vielen Dank für Deine Beschreibung. Top. Ich war tagelang happy. Nun bekomme ich plötzlich immer folgende Meldung. Kannst Du mir helfen?
ERROR:root:RequestException: 403 Client Error: Forbidden for url: https://semsportal.com/api/v1/PowerStation/GetMonitorDetailByPowerstationId
ERROR:root:RequestException: 403 Client Error: Forbidden for url: https://semsportal.com/api/v1/PowerStation/GetMonitorDetailByPowerstationId
ERROR:root:Failed to call GoodWe API url='https://semsportal.com/api/v1/PowerStation/GetMonitorDetailByPowerstationId'
ERROR:root:no inverter data, try True, trying again in 30 seconds
ERROR:root:RequestException: 403 Client Error: Forbidden for url: https://semsportal.com/api/v1/PowerStation/GetMonitorDetailByPowerstationId
ERROR:root:RequestException: 403 Client Error: Forbidden for url: https://semsportal.com/api/v1/PowerStation/GetMonitorDetailByPowerstationId
ERROR:root:Failed to call GoodWe API url='https://semsportal.com/api/v1/PowerStation/GetMonitorDetailByPowerstationId'
Traceback (most recent call last):
File "/home/pi/pygoodwe-master/allinone.py", line 8, in <module>
gw = SingleInverter(
File "/home/pi/pygoodwe-master/pygoodwe/init.py", line 446, in init
super().init(system_id, account, password, **kwargs)
File "/home/pi/pygoodwe-master/pygoodwe/init.py", line 60, in init
self.getCurrentReadings(raw=True)
File "/home/pi/pygoodwe-master/pygoodwe/init.py", line 456, in getCurrentReadings
super().getCurrentReadings(self, raw)
File "/home/pi/pygoodwe-master/pygoodwe/init.py", line 98, in getCurrentReadings
retval = self.getCurrentReadings(
File "/home/pi/pygoodwe-master/pygoodwe/init.py", line 456, in getCurrentReadings
super().getCurrentReadings(self, raw)
File "/home/pi/pygoodwe-master/pygoodwe/init.py", line 93, in getCurrentReadings
if retry < maxretries:
TypeError: '<' not supported between instances of 'SingleInverter' and 'int' -
Hi,
scheinbar scheint sich die API URL geändert zu haben, siehe hier -> https://github.com/yaleman/pygoodwe/issues/175
Du musst in der pygoodwe/init.py die URL von v1 in v2 ändern. Danach sollte es funktionieren.
-
Hallo, erstmal Dank für das tolle Script! Nach anfänglichen Schwierigkeiten hat es eine Weile ganz gut funktioniert. Die Umstellung auf die v2-API klappte auch reibungslos.
Jetzt verursacht nur der Wert der "Last" ein Problem, welches ist nach stundenlanger Recherche immer noch nicht beheben konnte. Evtl. hat hier einen einen Tipp?
script.js.common.goodwe: Fehler Python: Traceback (most recent call last): File "/opt/iobroker/pygoodwe/allinone.py", line 33, in <module> print(f"{gw.getLoadFlow()}") File "/opt/iobroker/pygoodwe/pygoodwe/__init__.py", line 353, in getLoadFlow if self.data['powerflow']['bettery'].endswith('(W)'):TypeError: 'NoneType' object is not subscriptableWenn ich in der allinone.py den zugehörigen Befehl auskommentiere funktioniert der Rest fehlerfrei:
print(f"{gw.getLoadFlow()}")LG Alex
-
Hallo, erstmal Dank für das tolle Script! Nach anfänglichen Schwierigkeiten hat es eine Weile ganz gut funktioniert. Die Umstellung auf die v2-API klappte auch reibungslos.
Jetzt verursacht nur der Wert der "Last" ein Problem, welches ist nach stundenlanger Recherche immer noch nicht beheben konnte. Evtl. hat hier einen einen Tipp?
script.js.common.goodwe: Fehler Python: Traceback (most recent call last): File "/opt/iobroker/pygoodwe/allinone.py", line 33, in <module> print(f"{gw.getLoadFlow()}") File "/opt/iobroker/pygoodwe/pygoodwe/__init__.py", line 353, in getLoadFlow if self.data['powerflow']['bettery'].endswith('(W)'):TypeError: 'NoneType' object is not subscriptableWenn ich in der allinone.py den zugehörigen Befehl auskommentiere funktioniert der Rest fehlerfrei:
print(f"{gw.getLoadFlow()}")LG Alex
@unbeliveable89 komisch, da es bei mir weiterhin funktioniert. Ich denke, würde es bei den anderen auch nicht funktionieren, hätten die sich sicherlich schon gemeldet.
-
Hmm, wirklich verrückt. Ich habe auch schon die neue init.py (0.0.17) übernommen, keine Auswirkungen. Alles funktioniert, nur der PowerFlow/die Last nicht.
Dann kann ich mir nur noch vorstellen, dass im WR selbst etwas verstellt wurde. GoodWe hat hier nämlich vor Wochen Updates eingespielt, da die Werte teilweise etwas inkonsequent waren.
Ansonsten bin ich wirklich Ratlos. Falls jemand noch etwas weiß, gerne mitteilen. :-)
Guten Rutsch allen!
-
@JB1985 Hallo JB
Jetzt hat dein Script so lange gearbeitet und jetzt will es nicht mehr. Kannst du mir mal wieder helfen?
Danke im vorraus

-
i kann die ./allinone.py nicht finden....
pi@raspberrypi:~/pygoodwe-master $ ./allinone.py
-bash: ./allinone.py: Datei oder Verzeichnis nicht gefunden -
@nr5lebt die Lösung steht weiter oben. Du musst die API URL von v1 nach v2 ändern.
https://forum.iobroker.net/topic/34626/goodwe-wechselrichter-und-iobroker/51?_=1672938480858
@jb1985 hallo jb,
hab das ganze wieder zum laufen bekommen. zumindest bis zum 19.1.. danach kam diese meldung:

ich komm auch nicht mehr auf die seite semsportal, die bricht mit einem timeout ab. auch mit der handyapp bekomm ich einen netzwerkfehler. bin mit meinem bischen latein am ende.
danke für die hilfe im vorraus -
@jb1985 hallo jb,
hab das ganze wieder zum laufen bekommen. zumindest bis zum 19.1.. danach kam diese meldung:

ich komm auch nicht mehr auf die seite semsportal, die bricht mit einem timeout ab. auch mit der handyapp bekomm ich einen netzwerkfehler. bin mit meinem bischen latein am ende.
danke für die hilfe im vorraus -
@jb1985 hallo jb,
hab das ganze wieder zum laufen bekommen. zumindest bis zum 19.1.. danach kam diese meldung:

ich komm auch nicht mehr auf die seite semsportal, die bricht mit einem timeout ab. auch mit der handyapp bekomm ich einen netzwerkfehler. bin mit meinem bischen latein am ende.
danke für die hilfe im vorraus -
@nr5lebt du bist an einem Limit von Seemsportal gekommen.
Du fragst zu oft ab. Am Besten alle 15 Minuten. Früher gibt es eh keine Aktualisierung.
Damit du wieder rein kommst, DSL Verbindung trennen damit du eine neue IP bekommst.
-
@silviu-vinicius-lungu said in GoodWe Wechselrichter und ioBroker:
i kann die ./allinone.py nicht finden....
pi@raspberrypi:~/pygoodwe-master $ ./allinone.py
-bash: ./allinone.py: Datei oder Verzeichnis nicht gefundenDas Problem hatte ich auch, habe eine neue Datei mit der Endung .py erstellt und mit den o.g. Daten gefüllt.
@jb1985 said in GoodWe Wechselrichter und ioBroker:
Hi,
scheinbar scheint sich die API URL geändert zu haben, siehe hier -> https://github.com/yaleman/pygoodwe/issues/175
Du musst in der pygoodwe/init.py die URL von v1 in v2 ändern. Danach sollte es funktionieren.
