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

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.
  • L Langer

    @jb1985

    Als erstes mal Danke für Deine Arbeit!!

    Bekomme nach Start der Javascript's folgende Fehlermeldungen:

    javascript.0
    2022-09-02 15:36:16.460	warn	script.js.common.PVAnlage.Goodwe: Fehler Python: ERROR:root:RequestException: HTTPSConnectionPool(host='semsportal.com', port=443): Read timed out. (read timeout=10)ERROR:root:RequestException during do_login(): HTTPSConnectionPool(host='semsportal.com', port=443): Read timed out. (read timeout=10)ERROR:root:Failed to log in, bailingERROR:root:no inverter data, try True, trying again in 30 secondsERROR:root:RequestException: HTTPSConnectionPool(host='semsportal.com', port=443): Read timed out. (read timeout=10)ERROR:root:RequestException: HTTPSConnectionPool(host='semsportal.com', port=443): Read timed out. (read timeout=10)ERROR:root:Failed to call GoodWe API url='https://semsportal.com/api/v1/PowerStation/GetMonitorDetailByPowerstationId'Traceback (most recent call last): File "/home/master/pygoodwe-master/allinone.py", line 8, in <module> gw = SingleInverter( File "/home/master/pygoodwe-master/pygoodwe/__init__.py", line 446, in __init__ super().__init__(system_id, account, password, **kwargs) File "/home/master/pygoodwe-master/pygoodwe/__init__.py", line 60, in __init__ self.getCurrentReadings(raw=True) File "/home/master/pygoodwe-master/pygoodwe/__init__.py", line 456, in getCurrentReadings super().getCurrentReadings(self, raw) File "/home/master/pygoodwe-master/pygoodwe/__init__.py", line 98, in getCurrentReadings retval = self.getCurrentReadings( File "/home/master/pygoodwe-master/pygoodwe/__init__.py", line 456, in getCurrentReadings super().getCurrentReadings(self, raw) File "/home/master/pygoodwe-master/pygoodwe/__init__.py", line 93, in getCurrentReadings if retry < maxretries:TypeError: '<' not supported between instances of 'SingleInverter' and 'int'
    

    und zwar alle 5 Minuten.

    Bekomme alle Werte.

    Wurde alles nach Deiner Anleitung Installiert. Wo habe ich eine Fehler gemacht?

    Vorab vielen Dank!!

    MfG
    Wastl

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

    @langer du hast gar kein Fehler gemacht, wenn deine Daten aktualisiert werden.

    Ich weiß auch nicht, ob es am Wechselrichter (schafft die mehrmaligen Anfragen nicht?) liegt oder an einer Überlastung des SEMS Portals.

    Zu sehen daran:

    (host='semsportal.com', port=443): Read timed out.
    

    Ich hab das in der App auch. Wenn ich manchmal aktualisieren will, kommt ein Fehler, dass die Daten nicht abgerufen werden. Weiß jetzt die genaue Fehlermeldung nicht.

    L 1 Antwort Letzte Antwort
    0
    • JB1985J JB1985

      @langer du hast gar kein Fehler gemacht, wenn deine Daten aktualisiert werden.

      Ich weiß auch nicht, ob es am Wechselrichter (schafft die mehrmaligen Anfragen nicht?) liegt oder an einer Überlastung des SEMS Portals.

      Zu sehen daran:

      (host='semsportal.com', port=443): Read timed out.
      

      Ich hab das in der App auch. Wenn ich manchmal aktualisieren will, kommt ein Fehler, dass die Daten nicht abgerufen werden. Weiß jetzt die genaue Fehlermeldung nicht.

      L Offline
      L Offline
      Langer
      schrieb am zuletzt editiert von Langer
      #39

      @jb1985

      Danke für Deine Antwort, hat bei mir etwas gedauert.

      Eine Frage noch, besteht die Möglichkeit alle Werte nach ioBroker in einen Datenpunkt zu speichern?

      Würde gerne weitere Daten auslesen.

      MfG
      Wastl

      JB1985J 1 Antwort Letzte Antwort
      0
      • L Langer

        @jb1985

        Danke für Deine Antwort, hat bei mir etwas gedauert.

        Eine Frage noch, besteht die Möglichkeit alle Werte nach ioBroker in einen Datenpunkt zu speichern?

        Würde gerne weitere Daten auslesen.

        MfG
        Wastl

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

        @langer sagte in GoodWe Wechselrichter und ioBroker:

        Eine Frage noch, besteht die Möglichkeit alle Werte nach ioBroker in einen Datenpunkt zu speichern?

        Du kannst speichern wo du willst. Du musst nur die Scripte anpassen.

        Würde gerne weitere Daten auslesen.

        Kannst du auch machen. Wie gesagt, man muss nur die Scripte anpassen.

        L 1 Antwort Letzte Antwort
        0
        • JB1985J JB1985

          @langer sagte in GoodWe Wechselrichter und ioBroker:

          Eine Frage noch, besteht die Möglichkeit alle Werte nach ioBroker in einen Datenpunkt zu speichern?

          Du kannst speichern wo du willst. Du musst nur die Scripte anpassen.

          Würde gerne weitere Daten auslesen.

          Kannst du auch machen. Wie gesagt, man muss nur die Scripte anpassen.

          L Offline
          L Offline
          Langer
          schrieb am zuletzt editiert von
          #41

          @jb1985

          Danke für Deine Antwort. Könntest Du mir ein kleines Beispiel geben, wo ich etwas ändern müßte?

          MfG
          Wastl

          JB1985J 1 Antwort Letzte Antwort
          0
          • L Langer

            @jb1985

            Danke für Deine Antwort. Könntest Du mir ein kleines Beispiel geben, wo ich etwas ändern müßte?

            MfG
            Wastl

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

            @langer hier wird in die Datenpunkte geschrieben:

            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);
            
               }
            
            }); 
            

            setState('Datenpunkte.0.PV-Anlage.PV_Strom_Gesamt', arr[6], true);

            allinone.py musst du dann erweitern.

            Wenn du aber keine Programmierkenntnisse hast, wird es schwierig.
            Bin auch nicht der Hardcore Programmierer.

            L 1 Antwort Letzte Antwort
            0
            • JB1985J JB1985

              @langer hier wird in die Datenpunkte geschrieben:

              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);
              
                 }
              
              }); 
              

              setState('Datenpunkte.0.PV-Anlage.PV_Strom_Gesamt', arr[6], true);

              allinone.py musst du dann erweitern.

              Wenn du aber keine Programmierkenntnisse hast, wird es schwierig.
              Bin auch nicht der Hardcore Programmierer.

              L Offline
              L Offline
              Langer
              schrieb am zuletzt editiert von
              #43

              @jb1985

              Nochmal Danke.

              Habe in allinone.py folgende Zeile eingefügt, "print(f"{gw.data}")" und bekomme auf dem Bildschirm die Ausgabe des Inhaltes von "gw.data".

              Wie bekomme ich den kompletten Inhalt von "gw.data" nach ioBroker?

              MfG
              Wastl

              JB1985J 1 Antwort Letzte Antwort
              0
              • L Langer

                @jb1985

                Nochmal Danke.

                Habe in allinone.py folgende Zeile eingefügt, "print(f"{gw.data}")" und bekomme auf dem Bildschirm die Ausgabe des Inhaltes von "gw.data".

                Wie bekomme ich den kompletten Inhalt von "gw.data" nach ioBroker?

                MfG
                Wastl

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

                @langer mit

                setState('Datenpunkte.0.PV-Anlage.PV_Strom_Gesamt', arr[6], true);

                Datenpunkte.0.PV-Anlage.PV_Strom_Gesamt' > musst du ändern in deinen Datenpunkt.

                arr[6], > musst du arr[7],

                machen oder evtl. höher. Der zählt immer einen höher.

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

                  Hallo,

                  Danke für das tolle Script + Anleitung! Läuft 1A bei mir.

                  Leider ist das Sems Portal dann schwer mit dem Handy erreichbar und sehr träge trotz 60sec timeout.

                  Hab nun endlich einen LAN Dongle und würde gerne per Modbus TCP mit dem IoBroker auslesen. Hast du bzw. jemand hier Erfahrung damit ?
                  Modbus Verbindung steht schon mal, leider bekomme ich noch keine Werte in meine Register.

                  Gruß

                  JB1985J 1 Antwort Letzte Antwort
                  0
                  • X xReactz

                    Hallo,

                    Danke für das tolle Script + Anleitung! Läuft 1A bei mir.

                    Leider ist das Sems Portal dann schwer mit dem Handy erreichbar und sehr träge trotz 60sec timeout.

                    Hab nun endlich einen LAN Dongle und würde gerne per Modbus TCP mit dem IoBroker auslesen. Hast du bzw. jemand hier Erfahrung damit ?
                    Modbus Verbindung steht schon mal, leider bekomme ich noch keine Werte in meine Register.

                    Gruß

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

                    @xreactz ich habe von Anfang an das LAN Dongle.

                    Als Tipp vorab! Trage eine statische IP ein. Bei DHCP verliert das LAN Dongle die Verbindung.

                    Mir ist nicht bekannt, dass GoodWe und Modbus TCP funktionieren. Wenn du da weiter kommst, dann berichte gerne mal hier.

                    X 1 Antwort Letzte Antwort
                    0
                    • JB1985J JB1985

                      @xreactz ich habe von Anfang an das LAN Dongle.

                      Als Tipp vorab! Trage eine statische IP ein. Bei DHCP verliert das LAN Dongle die Verbindung.

                      Mir ist nicht bekannt, dass GoodWe und Modbus TCP funktionieren. Wenn du da weiter kommst, dann berichte gerne mal hier.

                      X Offline
                      X Offline
                      xReactz
                      schrieb am zuletzt editiert von
                      #47

                      @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 1 Antwort Letzte Antwort
                      0
                      • 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
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          427

                                          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