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.
  • JB1985J JB1985

    @hellol du musst ein Zeitplan (cron) einrichten, so wie ich es geschrieben hatte:

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

    würde dann so aussehen:

    7dede463-b671-490d-94aa-6aee50c8dbc1-image.png

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

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


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          496

                                          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