NEWS
GoodWe Wechselrichter und ioBroker
-
Hallo,
bei mir läuft das pygoodwe-Script ohne Fehler durch, leider aber auch ohne Daten. Ich habe jetzt keine Idee wo ich weiter ansetzen kann, außer dass ich bis jetzt keinen Batteriespeicher habe. Muss ich dazu den Zugriff auf das Array anders gestalten?
Skript:
exec('sudo /var/services/homes/SynAdmin/pygoodwe-main/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);
}
});Ergebnis:
9:32:55.759 info javascript.0 (565) Stop script script.js.common.SolarGarage
09:32:55.844 info javascript.0 (565) Start javascript script.js.common.SolarGarage
09:32:55.855 info javascript.0 (565) script.js.common.SolarGarage: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptionsDie allinone und die config.py müssten auch passen, Kennung und Passwort habe ich jetzt ausge-xt:
allinone.py
#!/usr/bin/env python3import json
from config import args
from pygoodwe import SingleInverter, API#print("Single Inverter")
gw = SingleInverter(
system_id=args.get('8756ea7a-ecaf-4022-a9a9-86c233b837d9', '1'),
account=args.get('gw_account', 'xxxxxxxx'),
password=args.get('gw_password', 'xxxxxx'),
)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))
Im Semsportal sind die Werte da. Ich will lediglich Strom etotal und out_pac auslesen. Finde ich irgendwo das Array, da von Semsportal zur Verfügung steht?
Vielen Dank für eure Bemühungen.
Chris
-
Der eigentliche Fehler ist offenbar:
ERROR:root:Failed to call GoodWe API url='https://eu.semsportal.com/api/v2/PowerS
tation/GetMonitorDetailByPowerstationId'Wenn ich dies url eingebe dann stoße ich auf ein Script.
Falls hier jemand Erfahrungen hat....
MfG
Chris
-
@JB1985
Hallo wenn ich das so nach deiner Anleitung mache findet er das Verzeichnis "pygoodwe-master" nicht.
Was ist der Fehler? -
machst du mal ls -l und stellst vermutlich fest, dass das Verzeichnis wie bei mir "pygoodwe-main" heißt...
-
@chr-hu
Ja hast recht aber wie soll ich dann meine daten eintragen?
Weil wenn ich den Befehl eingebe zum daten eintragen kommt der Fehler das der Befehl nicht deklariert ist. -
Das Script hast du ja bereits, ich hänge das für den Überblick jetzt mal als Hardcopy rein:
Ich nehme da nur drei Werte raus, weil ich keine Batterie habe. Die anderen Felder habe ich nur als Kommentar drin gelassen.
Der Set-Befehl schreibt die Felder in den Iobroker, der Pfadname der Objekte muss im Skript genau stimmen:
Wenn du die Influxdb2 installiert hast UND den Influx-Adapter im Iobroker dann markierst du in den Feldeinstellungen hinten (Rädchen) die Objekte, die vom Influx-Adapter abgeholt werden und diese landen dann automatisch in der Datenbank. Leg die Objektnamen mit Pfad vorher genau fest, du kannst die Felder in der Datenbank dann nicht mehr umbenennen und auch nur schwer löschen.
Gruß
Chris
Achja: und die Array-Belegung habe ich in der allinone.py zusammengestellt und die überflüssigen prints ausge-#t, soweit ich mich erinnere. In der init.py müssen die v1-Strings gegen die v2 ausgetauscht werden.
-
@chr-hu
Danke erst mal.
Aber wenn ich den Befehlmv config.py.example config.py
eingebe kommt der Befehl wurde nicht gefunden.
Das ist momentan mein Problem -
Wo er Recht hat, da hat er Recht. Was soll das sein? Select ist ein sql-Befehl in der Datenbank, mv ist der Linuxbefehl zum Umbenennen. Was willst du wo machen?
-
@chr-hu
Ich möchte meine daten von SEMS Portal eintragen das ich die daten Abfragen kann.
Aber wo soll ich das machen wenn dieser Befehl falsch ist? -
@max-0 Ich glaub du bist ein bisschen weit weg. Du brauchst den IOBroker erstmal, dann das yaleman-Skript aus github installieren, dann z.b die Influx Datenbank und dann geht es bei meinem vorletzten Post weiter. Wo bist du und auf welcher Platform?
Chris
-
@chr-hu
Also den Iobroker habe ich.
Ich habe dann das yaleman-Skript mitsudo pip3 install pygoodwe
und
wget https://github.com/yaleman/pygoodwe/archive/master.zip unzip master.zip cd pygoodwe-master
in der Raspberry Konsole installiert.
Soweit bin ich momentan. -
Nun gut, ich habe keinen Raspi sondern Synology. Egal, python3 hast du auch am Laufen wenn pip3 gelaufen ist.
Dann schau mal dass du die pygoodwe-main/alinone.py zum laufen kriegst. In den Python-Dateien musst du vorher mit nem Editor /v1/ gegen /v2/ austauschen, dann bekommst du die letzten Werte testweise auf den Schirm. Dann geht es bei meinem obigen Post weiter und du bekommst diese Werte in den iobroker. Dann brauchst du noch die influxdb, die die Einzelwerte als Datenreihe abspeichert.
Mühsam ernährt sich das Eichhörnchen und springt von Ast zu Ast und sammelt Nüsse für den Winter...
-
@chr-hu
Es tut mir leid das ich dich hiermit nerfe, aber wie bekomme ich pyoodwe-main/alinone.py zum laufen?
Und wie soll ich die Datei editieren weil ich habe die ja nur auf meinem raspi und nicht auf dem PC? -
Hallo, habe mich heut mal wieder dran versucht und alles gemacht wie hier im Thread... In der Console holt er alle Daten wenn ich allinone.py starte...
Aber iobroker meint :
javascript.0 (553) script.js.pv-1: Fehler Python: undefined
Mein Script sieht so aus....
exec('/opt/pygoodsems/pygoodwe-main1/allinone.py', function (error, stdout, stderr) { if(error) log('Fehler Python: ' + stderr, 'warn'); else if(stdout) { let arr = stdout.split('\n'); setState('0_userdata.0.Bauer_PV_1.PV-Power', arr[0], true); setState('0_userdata.0.Bauer_PV_1.PV_Haus_Last', arr[3], true); setState('0_userdata.0.Bauer_PV_1.PV_Strom_zu_Stadtwerken', arr[4], true); setState('0_userdata.0.Bauer_PV_1.PV_Strom_Heute', arr[5], true); setState('0_userdata.0.Bauer_PV_1.PV_Strom_Gesamt', arr[6], true); } });
-
@v8turbo
Ah ok exec in der Instanz war Deaktiviert... Nun kommt....javascript.0 (3826) script.js.pv-1: Fehler Python: /opt/pygoodsems/pygoodwe-main1/allinone.py: 3: import: not found /opt/pygoodsems/pygoodwe-main1/allinone.py: 4: from: not found /opt/pygoodsems/pygoodwe-main1/allinone.py: 5: from: not found /opt/pygoodsems/pygoodwe-main1/allinone.py: 8: Syntax error: "(" unexpected
-
in der allinone.py Zeile 3-5
import json
from config import args
from pygoodwe import SingleInverter, APIPyhton erkennt den import-Befehl nicht. Da gibt es sicher Spezialisten im Forum, ich bin da jetzt nicht tiefer drin.
Frage ins Blaue: in meiner allinone.py steht in der ersten Zeile das Shebang: #!/usr/bin/env python3 . Hast du das auch drin?
Chris
-
@chr-hu
Danke, es war zwar drin aber vor dem # war ein leerzeichen ^^ -
Jetzt wäre nur noch mein Problem... Ich habe 2 WR einen GW30K-ET und einen GW30K-MT. Der ET ist klar, der MT hat einiges nicht was ausgelesen werden kann. z.b. Strom gesamt und Strom heute, da kommt als Wert {"ack":true} was bedeutet das ?
-
So nachdem ich nun alle 3min den Cron laufen lasse kommt
javascript.0 2024-03-06 09:15:37.993 warn script.js.pv-1: Fehler Python: ERROR:root:Failed to call GoodWe API url='https://eu.semsportal.com/api/v2/PowerStation/GetMonitorDetailByPowerstationId' ERROR:root:no inverter data, try 1, trying again in 30 seconds Traceback (most recent call last): File "/opt/pygoodsems/pygoodwe-main1/allinone.py", line 8, in <module> gw = SingleInverter( File "/usr/local/lib/python3.9/dist-packages/pygoodwe/__init__.py", line 432, in __init__ super().__init__( File "/usr/local/lib/python3.9/dist-packages/pygoodwe/__init__.py", line 75, in __init__ self.getCurrentReadings(raw=True) File "/usr/local/lib/python3.9/dist-packages/pygoodwe/__init__.py", line 457, in get_current_readings self.data["inverter"] = self.data["inverter"][0] KeyError: 0 javascript.0 2024-03-06 09:15:36.967 info State value to set for "0_userdata.0.Bauer_PV_2.PV_Strom_Gesamt" has to be type "string" but received type "object" javascript.0 2024-03-06 09:15:36.966 info State value to set for "0_userdata.0.Bauer_PV_2.PV_Strom_Heute" has to be type "string" but received type "object"
-