Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Praktische Anwendungen (Showcase)
  4. GoodWe Wechselrichter und ioBroker

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    2.9k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.1k

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.4k

GoodWe Wechselrichter und ioBroker

Scheduled Pinned Locked Moved Praktische Anwendungen (Showcase)
94 Posts 19 Posters 23.7k Views 21 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • Max 0M Offline
    Max 0M Offline
    Max 0
    wrote on last edited by
    #68

    @JB1985
    Hallo wenn ich das so nach deiner Anleitung mache findet er das Verzeichnis "pygoodwe-master" nicht.
    Was ist der Fehler?

    C 1 Reply Last reply
    0
    • Max 0M Max 0

      @JB1985
      Hallo wenn ich das so nach deiner Anleitung mache findet er das Verzeichnis "pygoodwe-master" nicht.
      Was ist der Fehler?

      C Offline
      C Offline
      Chr.Hu
      wrote on last edited by
      #69

      machst du mal ls -l und stellst vermutlich fest, dass das Verzeichnis wie bei mir "pygoodwe-main" heißt...

      8568511f-ea78-4da8-ba9c-2c85c2066455-image.png

      1 Reply Last reply
      0
      • Max 0M Offline
        Max 0M Offline
        Max 0
        wrote on last edited by Max 0
        #70

        @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.

        1 Reply Last reply
        0
        • C Offline
          C Offline
          Chr.Hu
          wrote on last edited by Chr.Hu
          #71

          Das Script hast du ja bereits, ich hänge das für den Überblick jetzt mal als Hardcopy rein:

          e93f342a-576c-4c9e-9753-40ff8d9a3e27-image.png

          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:

          f2015bef-330b-4894-8a0d-598b9b3a85b8-image.png

          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.

          Max 0M 1 Reply Last reply
          0
          • C Chr.Hu

            Das Script hast du ja bereits, ich hänge das für den Überblick jetzt mal als Hardcopy rein:

            e93f342a-576c-4c9e-9753-40ff8d9a3e27-image.png

            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:

            f2015bef-330b-4894-8a0d-598b9b3a85b8-image.png

            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.

            Max 0M Offline
            Max 0M Offline
            Max 0
            wrote on last edited by Max 0
            #72

            @chr-hu
            Danke erst mal.
            Aber wenn ich den Befehl

            mv config.py.example config.py
            

            eingebe kommt der Befehl wurde nicht gefunden.
            Das ist momentan mein Problem

            C 1 Reply Last reply
            0
            • Max 0M Max 0

              @chr-hu
              Danke erst mal.
              Aber wenn ich den Befehl

              mv config.py.example config.py
              

              eingebe kommt der Befehl wurde nicht gefunden.
              Das ist momentan mein Problem

              C Offline
              C Offline
              Chr.Hu
              wrote on last edited by
              #73

              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?

              Max 0M 1 Reply Last reply
              0
              • C Chr.Hu

                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?

                Max 0M Offline
                Max 0M Offline
                Max 0
                wrote on last edited by
                #74

                @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?

                1 Reply Last reply
                0
                • C Offline
                  C Offline
                  Chr.Hu
                  wrote on last edited by
                  #75

                  @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

                  Max 0M 1 Reply Last reply
                  0
                  • C Chr.Hu

                    @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

                    Max 0M Offline
                    Max 0M Offline
                    Max 0
                    wrote on last edited by
                    #76

                    @chr-hu
                    Also den Iobroker habe ich.
                    Ich habe dann das yaleman-Skript mit

                    sudo 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.

                    C 1 Reply Last reply
                    0
                    • Max 0M Max 0

                      @chr-hu
                      Also den Iobroker habe ich.
                      Ich habe dann das yaleman-Skript mit

                      sudo 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.

                      C Offline
                      C Offline
                      Chr.Hu
                      wrote on last edited by
                      #77

                      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...

                      1 Reply Last reply
                      0
                      • Max 0M Offline
                        Max 0M Offline
                        Max 0
                        wrote on last edited by Max 0
                        #78

                        @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?

                        1 Reply Last reply
                        0
                        • V Offline
                          V Offline
                          V8Turbo
                          wrote on last edited by
                          #79

                          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);
                          
                             }
                          
                          }); 
                          
                          V 1 Reply Last reply
                          0
                          • V V8Turbo

                            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);
                            
                               }
                            
                            }); 
                            
                            V Offline
                            V Offline
                            V8Turbo
                            wrote on last edited by
                            #80

                            @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 
                            
                            1 Reply Last reply
                            0
                            • C Offline
                              C Offline
                              Chr.Hu
                              wrote on last edited by Chr.Hu
                              #81

                              in der allinone.py Zeile 3-5

                              import json
                              from config import args
                              from pygoodwe import SingleInverter, API

                              Pyhton 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

                              V 1 Reply Last reply
                              0
                              • C Chr.Hu

                                in der allinone.py Zeile 3-5

                                import json
                                from config import args
                                from pygoodwe import SingleInverter, API

                                Pyhton 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

                                V Offline
                                V Offline
                                V8Turbo
                                wrote on last edited by V8Turbo
                                #82

                                @chr-hu
                                Danke, es war zwar drin aber vor dem # war ein leerzeichen ^^

                                1 Reply Last reply
                                0
                                • V Offline
                                  V Offline
                                  V8Turbo
                                  wrote on last edited by
                                  #83

                                  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 ?

                                  V 1 Reply Last reply
                                  0
                                  • V V8Turbo

                                    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 ?

                                    V Offline
                                    V Offline
                                    V8Turbo
                                    wrote on last edited by
                                    #84

                                    @v8turbo

                                    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" 
                                    
                                    C 1 Reply Last reply
                                    0
                                    • V V8Turbo

                                      @v8turbo

                                      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" 
                                      
                                      C Offline
                                      C Offline
                                      Chr.Hu
                                      wrote on last edited by
                                      #85

                                      @v8turbo

                                      Lass ihn alle 15 oder 30min laufen. Wahrscheinlich stolpert er...

                                      Chris

                                      M 1 Reply Last reply
                                      0
                                      • C Chr.Hu

                                        @v8turbo

                                        Lass ihn alle 15 oder 30min laufen. Wahrscheinlich stolpert er...

                                        Chris

                                        M Offline
                                        M Offline
                                        Mr.Flexible
                                        wrote on last edited by
                                        #86

                                        Hallo. Ich bekomme diesen Fehler und schaffe es nicht, die Ursache zu finden.

                                        script.js.common.GoodWe: Fehler Python: python3: can't open file '/home/admin/pygoodwe-main/allinone.py': [Errno 13] Permission denied

                                        Das Script allinone.py läuft im Terminal einwandfrei und zeigt die abgeholten Werte an. Nur das Script innerhalb von ioBroker läuft nicht.

                                        const exec = require('child_process').exec;

                                        exec('/usr/bin/python3 /home/admin/pygoodwe-main/allinone.py', function(error, stdout, stderr) {
                                        if (error) {
                                        console.log('Fehler Python: ' + stderr);
                                        return;
                                        }
                                        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);
                                        }
                                        });

                                        Ich habe bereits folgendes probiert:

                                        sudo chmod +x /home/admin/pygoodwe-main/allinone.py
                                        sudo chmod 755 /home/admin/pygoodwe-main
                                        sudo chown -R admin:admin /home/admin/pygoodwe-main

                                        Unter Instanzen habe ich dem Modul Javascript die <exec>-Rechte gewährt.

                                        Wer hat noch eine zielführende Idee?

                                        Vielen Dank!
                                        MrF

                                        M 1 Reply Last reply
                                        0
                                        • M Mr.Flexible

                                          Hallo. Ich bekomme diesen Fehler und schaffe es nicht, die Ursache zu finden.

                                          script.js.common.GoodWe: Fehler Python: python3: can't open file '/home/admin/pygoodwe-main/allinone.py': [Errno 13] Permission denied

                                          Das Script allinone.py läuft im Terminal einwandfrei und zeigt die abgeholten Werte an. Nur das Script innerhalb von ioBroker läuft nicht.

                                          const exec = require('child_process').exec;

                                          exec('/usr/bin/python3 /home/admin/pygoodwe-main/allinone.py', function(error, stdout, stderr) {
                                          if (error) {
                                          console.log('Fehler Python: ' + stderr);
                                          return;
                                          }
                                          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);
                                          }
                                          });

                                          Ich habe bereits folgendes probiert:

                                          sudo chmod +x /home/admin/pygoodwe-main/allinone.py
                                          sudo chmod 755 /home/admin/pygoodwe-main
                                          sudo chown -R admin:admin /home/admin/pygoodwe-main

                                          Unter Instanzen habe ich dem Modul Javascript die <exec>-Rechte gewährt.

                                          Wer hat noch eine zielführende Idee?

                                          Vielen Dank!
                                          MrF

                                          M Offline
                                          M Offline
                                          Mr.Flexible
                                          wrote on last edited by
                                          #87

                                          @mr-flexible Gelöst! Siehe https://forum.iobroker.net/topic/74824/gelöst-permission-denied-fehler-goodwe-script

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          724

                                          Online

                                          32.6k

                                          Users

                                          82.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe