Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

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

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.9k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.3k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.4k

GoodWe Wechselrichter und ioBroker

Geplant Angeheftet Gesperrt Verschoben Praktische Anwendungen (Showcase)
94 Beiträge 19 Kommentatoren 22.1k Aufrufe 21 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • V Offline
    V Offline
    V8Turbo
    schrieb am zuletzt editiert von
    #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 Antwort Letzte Antwort
    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
      schrieb am zuletzt editiert von
      #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 Antwort Letzte Antwort
      0
      • C Offline
        C Offline
        Chr.Hu
        schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
        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
          schrieb am zuletzt editiert von V8Turbo
          #82

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

          1 Antwort Letzte Antwort
          0
          • V Offline
            V Offline
            V8Turbo
            schrieb am zuletzt editiert von
            #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 Antwort Letzte Antwort
            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
              schrieb am zuletzt editiert von
              #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 Antwort Letzte Antwort
              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
                schrieb am zuletzt editiert von
                #85

                @v8turbo

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

                Chris

                M 1 Antwort Letzte Antwort
                0
                • C Chr.Hu

                  @v8turbo

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

                  Chris

                  M Offline
                  M Offline
                  Mr.Flexible
                  schrieb am zuletzt editiert von
                  #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 Antwort Letzte Antwort
                  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
                    schrieb am zuletzt editiert von
                    #87

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

                    1 Antwort Letzte Antwort
                    0
                    • U Offline
                      U Offline
                      unicornch
                      schrieb am zuletzt editiert von
                      #88

                      Hallo zusammen,

                      für alle, bei denen das Script seit einigen Tagen keine Daten mehr liefert:

                      In der Datei:
                      ~/pygoodwe-main/pygoodwe/__init__.py

                      bei Zeile 290 folgendes einfügen:

                                  # APIs return "success", "Success", "Successful" in the 'msg'
                                  # seen "Successful" in ExportPowerStationPac
                                  # logging.error("Msg result %s - %s", self.base_url + url, data.get('msg', ''))
                                  if (
                                      data.get("msg", "").lower()
                                      in (
                                          "success",
                                          "successful",
                                          "操作成功",
                                      )
                      

                      Das API scheint plötzlich auf chinesisch zu antworten.

                      Gruss,
                      Peter

                      Rap achoR KevinL214K 2 Antworten Letzte Antwort
                      0
                      • U unicornch

                        Hallo zusammen,

                        für alle, bei denen das Script seit einigen Tagen keine Daten mehr liefert:

                        In der Datei:
                        ~/pygoodwe-main/pygoodwe/__init__.py

                        bei Zeile 290 folgendes einfügen:

                                    # APIs return "success", "Success", "Successful" in the 'msg'
                                    # seen "Successful" in ExportPowerStationPac
                                    # logging.error("Msg result %s - %s", self.base_url + url, data.get('msg', ''))
                                    if (
                                        data.get("msg", "").lower()
                                        in (
                                            "success",
                                            "successful",
                                            "操作成功",
                                        )
                        

                        Das API scheint plötzlich auf chinesisch zu antworten.

                        Gruss,
                        Peter

                        Rap achoR Offline
                        Rap achoR Offline
                        Rap acho
                        schrieb am zuletzt editiert von Samson71
                        #89

                        @unicornch
                        vielen dank dafür allerdings habe ich auch seit genau montag das problem es kommen keine daten mehr an. obwohl ich seit monaten nichts veränder habe.

                        die daten sind in der config richtig hinterlegt aber das allinoy funktioniert nicht. es kommt folgendes:

                        python3 /home/matheus/pygoodwe-main/allinone.py
                        ERROR:root:Failed to call GoodWe API url='https://eu.semsportal.com/api/v2/Power                                                         Station/GetMonitorDetailByPowerstationId'
                        ERROR:root:no inverter data, try 1, trying again in 30 seconds
                        ERROR:root:Failed to call GoodWe API url='https://eu.semsportal.com/api/v2/Power                                                         Station/GetMonitorDetailByPowerstationId'
                        

                        das habe ich als fehler im putty

                        MOD-EDIT
                        Bitte Code-Tags </> benutzen

                        1 Antwort Letzte Antwort
                        0
                        • U unicornch

                          Hallo zusammen,

                          für alle, bei denen das Script seit einigen Tagen keine Daten mehr liefert:

                          In der Datei:
                          ~/pygoodwe-main/pygoodwe/__init__.py

                          bei Zeile 290 folgendes einfügen:

                                      # APIs return "success", "Success", "Successful" in the 'msg'
                                      # seen "Successful" in ExportPowerStationPac
                                      # logging.error("Msg result %s - %s", self.base_url + url, data.get('msg', ''))
                                      if (
                                          data.get("msg", "").lower()
                                          in (
                                              "success",
                                              "successful",
                                              "操作成功",
                                          )
                          

                          Das API scheint plötzlich auf chinesisch zu antworten.

                          Gruss,
                          Peter

                          KevinL214K Offline
                          KevinL214K Offline
                          KevinL214
                          schrieb am zuletzt editiert von
                          #90

                          @unicornch Danke dir. Erspart mir viel Arbeit :flushed:

                          @Rap-acho Bei mir kam die selbe Meldung. Nach der Änderung laut @unicornch ging es bei mir wieder.
                          aktiviere mal den Log und schau mal was er dir meldet:

                          # logging.error("Msg result %s - %s", self.base_url + url, data.get('msg', ''))
                          

                          Liebe Grüße

                          Rap achoR 1 Antwort Letzte Antwort
                          0
                          • KevinL214K KevinL214

                            @unicornch Danke dir. Erspart mir viel Arbeit :flushed:

                            @Rap-acho Bei mir kam die selbe Meldung. Nach der Änderung laut @unicornch ging es bei mir wieder.
                            aktiviere mal den Log und schau mal was er dir meldet:

                            # logging.error("Msg result %s - %s", self.base_url + url, data.get('msg', ''))
                            

                            Liebe Grüße

                            Rap achoR Offline
                            Rap achoR Offline
                            Rap acho
                            schrieb am zuletzt editiert von
                            #91

                            was mir aufegefallen ist... als ich das eingefügt habe "操作成功", und gespeichert habe. und die datei wieder geöffnet habe wurden statt der zeichen nur ????? angezeigt. also musste ich noch die passenden fonts installlieren.

                            sudo apt update
                            sudo apt install fonts-noto-cjk
                            

                            und dann noch

                            sudo apt install fonts-arphic-uming fonts-arphic-ukai
                            

                            installiert und danach neugestartet

                            danach die datei nochmal bearbeitet und das hinzugefügt "操作成功"

                            danach hat er aus so angenommen und das script läuft wieder. danke

                            1 Antwort Letzte Antwort
                            1
                            • C Chr.Hu

                              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

                              T Offline
                              T Offline
                              Tomapyrinz
                              schrieb am zuletzt editiert von
                              #92

                              @chr-hu said in GoodWe Wechselrichter und ioBroker:

                              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

                              Hallo Chris,
                              an diesem Fehler hänge ich auch seit geraumer Zeit. Leider weiß ich nicht wo ich ansetzen soll, um den Fehler zu beheben.
                              Ich betreibe einen Raspy, keine Synology. Aber vielleicht kannst du mir trotzdem weiterhelfen bei der Fehlersuche. Was hat das Problem bei dir gelöst?
                              Grüße
                              Michael

                              C 1 Antwort Letzte Antwort
                              0
                              • T Tomapyrinz

                                @chr-hu said in GoodWe Wechselrichter und ioBroker:

                                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

                                Hallo Chris,
                                an diesem Fehler hänge ich auch seit geraumer Zeit. Leider weiß ich nicht wo ich ansetzen soll, um den Fehler zu beheben.
                                Ich betreibe einen Raspy, keine Synology. Aber vielleicht kannst du mir trotzdem weiterhelfen bei der Fehlersuche. Was hat das Problem bei dir gelöst?
                                Grüße
                                Michael

                                C Offline
                                C Offline
                                Chr.Hu
                                schrieb am zuletzt editiert von
                                #93

                                @tomapyrinz

                                Hallo,

                                das weiß ich leider nicht mehr im Detail, an was es da gehakt hat.

                                Generell hatte ich mir notiert https://forum.iobroker.net/topic/34626/goodwe-wechselrichter-und-iobroker

                                Vielleicht kommst du das weiter.

                                Gruß

                                Chris

                                C 1 Antwort Letzte Antwort
                                0
                                • C Chr.Hu

                                  @tomapyrinz

                                  Hallo,

                                  das weiß ich leider nicht mehr im Detail, an was es da gehakt hat.

                                  Generell hatte ich mir notiert https://forum.iobroker.net/topic/34626/goodwe-wechselrichter-und-iobroker

                                  Vielleicht kommst du das weiter.

                                  Gruß

                                  Chris

                                  C Offline
                                  C Offline
                                  Chr.Hu
                                  schrieb am zuletzt editiert von
                                  #94

                                  @chr-hu

                                  Mit der Chinesen-Übersetzung von "success" funktioniert der Zugriff wieder, vielen Dank @unicornch. Geht wohl auf den Zoll-Streit zurück, dass Goodwe nicht mehr auf Englisch antwortet :-)

                                  Den Schriftsatz musste ich nicht installieren.

                                  Chris

                                  1 Antwort Letzte Antwort
                                  0
                                  Antworten
                                  • In einem neuen Thema antworten
                                  Anmelden zum Antworten
                                  • Älteste zuerst
                                  • Neuste zuerst
                                  • Meiste Stimmen


                                  Support us

                                  ioBroker
                                  Community Adapters
                                  Donate

                                  767

                                  Online

                                  32.4k

                                  Benutzer

                                  81.6k

                                  Themen

                                  1.3m

                                  Beiträge
                                  Community
                                  Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                  ioBroker Community 2014-2025
                                  logo
                                  • Anmelden

                                  • Du hast noch kein Konto? Registrieren

                                  • Anmelden oder registrieren, um zu suchen
                                  • Erster Beitrag
                                    Letzter Beitrag
                                  0
                                  • Home
                                  • Aktuell
                                  • Tags
                                  • Ungelesen 0
                                  • Kategorien
                                  • Unreplied
                                  • Beliebt
                                  • GitHub
                                  • Docu
                                  • Hilfe