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

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

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

GoodWe Wechselrichter und ioBroker

Geplant Angeheftet Gesperrt Verschoben Praktische Anwendungen (Showcase)
94 Beiträge 19 Kommentatoren 22.0k 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.
  • X xReactz

    @jb1985

    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!

    08026fae-9cc0-44f6-b54b-bf07cd608571-grafik.png

    Gruß

    JB1985J Offline
    JB1985J Offline
    JB1985
    schrieb am zuletzt editiert von
    #48

    @xreactz können wir uns da irgendwie austauschen? Vielleicht machst du ein neues Thema im ioBroker Forum auf?

    Ich habe es mit modbus v5.0.5 probiert.

    eccaa1ca-c3ce-4e35-9c9b-1708b3b4c625-image.png

    1 Antwort Letzte Antwort
    0
    • X Offline
      X Offline
      xReactz
      schrieb am zuletzt editiert von
      #49

      @jb1985

      Hab ein eigenes Topic erstellt: https://forum.iobroker.net/topic/59207/goodwe-wechselrichter-und-modbus-tcp

      Hoffe es hilft, ich bin schon auf eure Rückmeldungen gespannt ! :handshake:

      Gruß

      1 Antwort Letzte Antwort
      0
      • JB1985J JB1985

        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:

        1. pygoodwe installieren:
        sudo pip3 install pygoodwe
        
        1. 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
        
        1. Die Zugangsdaten vom SEMS Portal trägt Ihr nun in der config.py ein:
        mv config.py.example config.py
        


        args = {
        'gw_station_id' : 'aaabbbbb-cccc-dddd-eeee-ffffffgggggg' ,
        'gw_account' : 'user@example.com',
        'gw_password' : 'darkHorseBatteryStaple123',
        'city' : 'London',
        }

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

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

        Attachment0.jpeg

        Viel Spaß damit!

        K Offline
        K Offline
        Kasalevi
        schrieb am zuletzt editiert von
        #50

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

        JB1985J 1 Antwort Letzte Antwort
        0
        • K Kasalevi

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

          JB1985J Offline
          JB1985J Offline
          JB1985
          schrieb am zuletzt editiert von
          #51

          @kasalevi

          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.

          K 1 Antwort Letzte Antwort
          0
          • JB1985J JB1985

            @kasalevi

            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.

            K Offline
            K Offline
            Kasalevi
            schrieb am zuletzt editiert von Kasalevi
            #52

            @jb1985 das wars. großartiger support. danke

            1 Antwort Letzte Antwort
            0
            • U Offline
              U Offline
              Unbeliveable89
              schrieb am zuletzt editiert von
              #53

              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 subscriptable
              

              Wenn ich in der allinone.py den zugehörigen Befehl auskommentiere funktioniert der Rest fehlerfrei:

              print(f"{gw.getLoadFlow()}")
              
              

              LG Alex

              JB1985J 1 Antwort Letzte Antwort
              0
              • U Unbeliveable89

                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 subscriptable
                

                Wenn ich in der allinone.py den zugehörigen Befehl auskommentiere funktioniert der Rest fehlerfrei:

                print(f"{gw.getLoadFlow()}")
                
                

                LG Alex

                JB1985J Offline
                JB1985J Offline
                JB1985
                schrieb am zuletzt editiert von
                #54

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

                1 Antwort Letzte Antwort
                0
                • U Offline
                  U Offline
                  Unbeliveable89
                  schrieb am zuletzt editiert von
                  #55

                  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!

                  1 Antwort Letzte Antwort
                  0
                  • N Offline
                    N Offline
                    Nr5lebt
                    schrieb am zuletzt editiert von
                    #56

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

                    JB1985J 1 Antwort Letzte Antwort
                    0
                    • N Nr5lebt

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

                      JB1985J Offline
                      JB1985J Offline
                      JB1985
                      schrieb am zuletzt editiert von JB1985
                      #57

                      @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

                      N 1 Antwort Letzte Antwort
                      0
                      • silviu-vinicius lunguS Offline
                        silviu-vinicius lunguS Offline
                        silviu-vinicius lungu
                        schrieb am zuletzt editiert von silviu-vinicius lungu
                        #58

                        i kann die ./allinone.py nicht finden....

                        pi@raspberrypi:~/pygoodwe-master $ ./allinone.py
                        -bash: ./allinone.py: Datei oder Verzeichnis nicht gefunden

                        1 Antwort Letzte Antwort
                        0
                        • JB1985J JB1985

                          @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

                          N Offline
                          N Offline
                          Nr5lebt
                          schrieb am zuletzt editiert von
                          #59

                          @jb1985 hallo jb,
                          hab das ganze wieder zum laufen bekommen. zumindest bis zum 19.1.. danach kam diese meldung:
                          Screenshot 2023-01-29 at 00-36-21 logs - nas.png
                          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

                          wendy2702W JB1985J 2 Antworten Letzte Antwort
                          0
                          • N Nr5lebt

                            @jb1985 hallo jb,
                            hab das ganze wieder zum laufen bekommen. zumindest bis zum 19.1.. danach kam diese meldung:
                            Screenshot 2023-01-29 at 00-36-21 logs - nas.png
                            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

                            wendy2702W Offline
                            wendy2702W Offline
                            wendy2702
                            schrieb am zuletzt editiert von
                            #60

                            @nr5lebt LOgfiles bitte als Text in Code Tags </> hier hin kopieren.

                            Den screenshot kann man mobil nur schwer entziffern und nicht zitieren.

                            Bitte keine Fragen per PN, die gehören ins Forum!

                            Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                            1 Antwort Letzte Antwort
                            0
                            • N Nr5lebt

                              @jb1985 hallo jb,
                              hab das ganze wieder zum laufen bekommen. zumindest bis zum 19.1.. danach kam diese meldung:
                              Screenshot 2023-01-29 at 00-36-21 logs - nas.png
                              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

                              JB1985J Offline
                              JB1985J Offline
                              JB1985
                              schrieb am zuletzt editiert von
                              #61

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

                              N 1 Antwort Letzte Antwort
                              0
                              • JB1985J JB1985

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

                                N Offline
                                N Offline
                                Nr5lebt
                                schrieb am zuletzt editiert von
                                #62

                                @jb1985 Danke zusammen, mit der neuen IP hatte ich gestern schon versucht aber immer noch nichts neues bekommen. Jetzt noch mal versucht und es klappt. Hatte die Zeiten auf 3 Minuten eingestellt. Jetzt auf 15 Minuten geändert. Danke zusammen noch mal

                                1 Antwort Letzte Antwort
                                0
                                • S Offline
                                  S Offline
                                  SushiQuatro
                                  schrieb am zuletzt editiert von SushiQuatro
                                  #63

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

                                  Das 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:

                                  @kasalevi

                                  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.

                                  V 1 Antwort Letzte Antwort
                                  0
                                  • S SushiQuatro

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

                                    Das 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:

                                    @kasalevi

                                    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.

                                    V Offline
                                    V Offline
                                    V8Turbo
                                    schrieb am zuletzt editiert von
                                    #64

                                    @sushiquatro

                                    Hallo, habe das gleiche Problem... Im aktuellen Paket auf Github ist die allinone.py nicht drin... Was tun ?

                                    Wenn ich die Werte vom 1. Post reinkopiere kommen haufen Fehler.

                                    Es muss doch eine aktuelle geben ?!?

                                    V 1 Antwort Letzte Antwort
                                    0
                                    • V V8Turbo

                                      @sushiquatro

                                      Hallo, habe das gleiche Problem... Im aktuellen Paket auf Github ist die allinone.py nicht drin... Was tun ?

                                      Wenn ich die Werte vom 1. Post reinkopiere kommen haufen Fehler.

                                      Es muss doch eine aktuelle geben ?!?

                                      V Offline
                                      V Offline
                                      V8Turbo
                                      schrieb am zuletzt editiert von V8Turbo
                                      #65

                                      @v8turbo

                                      xxx@raspberrypi:/etc/pygoodwe-main $ sudo ./allinone.py
                                      ./allinone.py: 3: import: not found
                                      ./allinone.py: 4: from: not found
                                      ./allinone.py: 5: from: not found
                                      ./allinone.py: 8: Syntax error: "(" unexpected
                                      
                                      

                                      EDIT:

                                      Ahh mit "python3 allinone.py" geht es.

                                      1 Antwort Letzte Antwort
                                      0
                                      • C Offline
                                        C Offline
                                        Chr.Hu
                                        schrieb am zuletzt editiert von Chr.Hu
                                        #66

                                        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 subscriptions

                                        e29503b0-3750-4967-94a0-fea02bd93164-image.png

                                        Die allinone und die config.py müssten auch passen, Kennung und Passwort habe ich jetzt ausge-xt:

                                        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('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

                                        C 1 Antwort Letzte Antwort
                                        0
                                        • C Chr.Hu

                                          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 subscriptions

                                          e29503b0-3750-4967-94a0-fea02bd93164-image.png

                                          Die allinone und die config.py müssten auch passen, Kennung und Passwort habe ich jetzt ausge-xt:

                                          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('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

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

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

                                          813

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          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