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

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.
  • H Hellol

    @jb1985 Vielen dank für die tolle Anleitung
    Ich bin neu im Thema scripts etc. Hab die datenpunkte in meinen iobroker rein bekommen. Jetzt hab ich nur noch das Problem, dass ich das Skript manuell an und aus machen muss, damit sich die Datenpunkte aktualisieren. Wie bekomme ich das Blockly zum laufen, sodass das Skript automatisch neu gestartet wird?

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

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


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          332

                                          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