Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Huawei Sun2000 & ioBroker via JS script funktioniert

    NEWS

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    Huawei Sun2000 & ioBroker via JS script funktioniert

    This topic has been deleted. Only users with topic management privileges can see it.
    • B
      baerengraben last edited by

      @Chris_B Vielen Dank für dieses sehr nützliche Skript!

      1 Reply Last reply Reply Quote 0
      • R
        R4 @Chris_B last edited by

        @chris_b
        Zeile 3 "modidfied"
        ... ne, ich schau es mir mal kritisch an 😉

        C 1 Reply Last reply Reply Quote 0
        • H
          hussi last edited by

          Wenn ich die aktuelle Leistung der PV in den Objekten sehen möchte, kann es dann sein, dass man dazu javascript.0.Solarpower.Huawei.Inverter.1.InputPower auslesen sollte?

          Wenn der Akku nicht voll ist, zeigt mir Solarpower.Huawei.Inverter.1.ActivePower nicht den korrekten Wert an. Sobald der Akku voll ist stimmt der Wert.

          Oder man rechnet Solarpower.Huawei.Inverter.1.ActivePower und javascript.0.Solarpower.Huawei.Inverter.1.Batterystack.1.ChargeAndDischargePower zusammen?

          C 1 Reply Last reply Reply Quote 0
          • C
            Chris_B @R4 last edited by

            @r4 Danke - ein stottttter typo.
            Habe ich korrigiert und das Readme auf Github schnell mit Information befüllt. Muss aber noch verbessert werden.

            1 Reply Last reply Reply Quote 0
            • C
              Chris_B @hussi last edited by

              @hussi Am besten einmal meine (neue) Github Seite anschauen. Dort sollte alles im Readme File erklärt sein. Ich werde das Readme in nächster Zeit noch erweitern und verbessern. Gruss

              https://github.com/ChrisBCH/SunLuna2000_iobroker

              1 Reply Last reply Reply Quote 2
              • H
                heinzie last edited by heinzie

                Hallo,

                erst mal Danke für das Script, ich verwende die Version 3 und läuft auch soweit ohne Probleme.

                Das einzige Problem ist, dass es alle paar Tage Morgens nicht mehr richtig läuft. Es hat dann Probleme die Werte zu lesen, siehe unten.
                Wenn ich es dann noch einmal neu starte läuft es wieder ohne Probleme.

                Eine Idee woran das leigen könnte?

                214da48a-7eec-48e8-a95a-b96f75e0bc1d-grafik.png

                R 1 Reply Last reply Reply Quote 0
                • R
                  R4 @heinzie last edited by R4

                  @heinzie
                  Du könntest versuchen in der Funktion readRegisterSpace() den auskommentierten Bereich zu aktivieren, also:

                  function readRegisterSpace(id, address, length)
                  //---------------------------------------------
                   {
                      client.setID(ModBusIDs[id-1]);
                      client.readHoldingRegisters(address, length, function(err, data)
                      {   
                          if (err)
                          {   
                              if (err.modbusCode == null)
                              {   console.warn("Lost connection to client. Trying to reconnect...");
                                  ConnectModbus();
                              } else             
                              console.warn("Error received reading address " + address + " from id: " + ModBusIDs[id-1] + " with error: " + modbusErrorMessages[err.modbusCode]);            
                          }
                          else
                          {   //console.debug("Read data from id/address " + ModBusIDs[id-1] + "/" + address + "\nData is: " + data.data);
                              for (var i = 0; i < length; i++) Buffer[id-1][address + i - BufOffset] = data.data[i];
                          }
                      });
                  }
                  
                  H 1 Reply Last reply Reply Quote 0
                  • H
                    heinzie @R4 last edited by

                    @r4 sagte in Huawei Sun2000 & ioBroker via JS script funktioniert:

                    @heinzie
                    Du könntest versuchen in der Funktion readRegisterSpace() den auskommentierten Bereich zu aktivieren, also:

                    function readRegisterSpace(id, address, length)
                    //---------------------------------------------
                     {
                        client.setID(ModBusIDs[id-1]);
                        client.readHoldingRegisters(address, length, function(err, data)
                        {   
                            if (err)
                            {   
                                if (err.modbusCode == null)
                                {   console.warn("Lost connection to client. Trying to reconnect...");
                                    ConnectModbus();
                                } else             
                                console.warn("Error received reading address " + address + " from id: " + ModBusIDs[id-1] + " with error: " + modbusErrorMessages[err.modbusCode]);            
                            }
                            else
                            {   //console.debug("Read data from id/address " + ModBusIDs[id-1] + "/" + address + "\nData is: " + data.data);
                                for (var i = 0; i < length; i++) Buffer[id-1][address + i - BufOffset] = data.data[i];
                            }
                        });
                    }
                    

                    Danke, habe ich einmal geändert, werde mich dann nach Test wieder melden.

                    Axel Koeneke 1 Reply Last reply Reply Quote 0
                    • Axel Koeneke
                      Axel Koeneke @heinzie last edited by

                      Hallo zusammen,
                      ich habe mal eine generelle Frage, da ich gerade über einen Umbau meiner PV nachdenke. Da bei meiner bestehenden Anlage (SMA ohne Akku), bald die Vergütung entfällt, möchte ich gerne auf "Null-Einspeisung" umbauen. Kann man den Huawei mittels diesem Script damit entsprechend steuern, bzw drosseln?
                      VG Axel

                      R 1 Reply Last reply Reply Quote 0
                      • R
                        R4 @Axel Koeneke last edited by

                        @axel-koeneke
                        du meinst das hier?

                        Axel Koeneke 1 Reply Last reply Reply Quote 0
                        • R
                          rainereglinsky @rainereglinsky last edited by

                          @rainereglinsky Wer hat auch noch das Problem, dass ConsumptionSum und ConsumptionToday immer gleiche Werte anzeigen?

                          86b3595d-d1ab-4bb0-a1d1-f92fe19f03c8-image.png

                          R C 2 Replies Last reply Reply Quote 0
                          • R
                            R4 @rainereglinsky last edited by

                            @rainereglinsky
                            Dein
                            schedule("59 23 * * *", function () {...}
                            tut nicht. Lässt du das Script tagelang durchlaufen? Hast du was rausgelöscht?

                            1 Reply Last reply Reply Quote 0
                            • C
                              Chris_B @rainereglinsky last edited by

                              @rainereglinsky Lass das Skript einmal schön brav über Mitternacht laufen. Tut genau so wie es soll. Die Initialisierung könnte man besser machen. Also: lass das Skript laufen, und am nächsten Tag ist alles OK. Gruss

                              R 1 Reply Last reply Reply Quote 0
                              • R
                                rainereglinsky @Chris_B last edited by

                                @chris_b
                                danke, habe erst seit gestern den neuen Raspby aufgesetzt, schaue morgen dann mal wieder rein.

                                R 1 Reply Last reply Reply Quote 0
                                • C
                                  Chris_B last edited by

                                  Kleines Problem bei der Energie-Berechnung:
                                  Laut den Angaben die mir vorliegen, berechnet sich der 'Portal Yield Today' nach folgender Formel (in Klammer Modbus IDs):

                                  PortalYieldToday =
                                  DailyEnergyYield (32114) - CurrentDayChargeCapacity (37015) - CurrentDayDischargeCapacity (37017)

                                  Die Formel stimmt meist gut mit dem im Huawei Portal überein, aber eben nicht immer.
                                  Hat irgend jemand eine Idee wieso, oder wie Huawei das im Portal genau rechnet?

                                  C 1 Reply Last reply Reply Quote 0
                                  • Axel Koeneke
                                    Axel Koeneke @R4 last edited by

                                    @r4 Danke für den Link, also der WR kann das alleine (wenn man einen zusätzlichen Sensor verbaut). Ich dachte das könnte man auch mit dem Script realisieren.
                                    VG Axel

                                    1 Reply Last reply Reply Quote 0
                                    • C
                                      Chris_B @Chris_B last edited by

                                      Neues Skript auf Github. Folgende Änderungen:

                                      1. Das Skript liest mehr Batteriedaten, vor allem auch betreffen laden der Batterie aus dem Netz.
                                      2. Dokumentation ergänzt, vor allem auch das Issue zum Daily Yield ist jetzt beschrieben.

                                      Hier nchmals der Link:
                                      Github-Sun2000

                                      B 1 Reply Last reply Reply Quote 1
                                      • B
                                        badsnoopy667 @Chris_B last edited by

                                        @chris_b said in Huawei Sun2000 & ioBroker via JS script funktioniert:

                                        Das Skript liest mehr Batteriedaten, vor allem auch betreffen laden der Batterie aus dem Netz.

                                        Hallo Chris, danke für das neue Skript. Aktuell nutze ich noch node-red, spiele aber mit dem Gedanken auf das Skript zu wechseln. Was ich über node-red nicht hinbekomme: Der Batterie sagen, dass sie aus dem Netz laden soll (z.B. bei variablem Stromtarif).
                                        Ist das mit Deinem Skript möglich? Das wär der Knaller!

                                        Viele Grüße
                                        Jan

                                        C 1 Reply Last reply Reply Quote 0
                                        • C
                                          Chris_B @badsnoopy667 last edited by

                                          @badsnoopy667 Hallo Jan. Momentan ist eine Schreibfunktion noch nicht implementiert. Es gibt aber einen Vorschlag von @R4 , der relativ leicht zu implementieren sein sollte. Ich möchte das in einer nächsten Version auch noch implementieren. Weiss aber noch nicht, wann cih dazu komme, da ich beruflich gerade ziemlich engagiert und unterwegs sein werde. Einfach etwas Geduld noch... Gruss

                                          1 Reply Last reply Reply Quote 1
                                          • R
                                            rainereglinsky @rainereglinsky last edited by

                                            @rainereglinsky Hilfe!
                                            hatte bis gestern ein toll funktionierenden Raspi 4 mit dem JS script laufen - alles war gut. Habe dann den Raspi fertig gemacht für den headless Betrieb - immer noch alles bestens.
                                            Heute bekomme ich keine Daten mehr aus meiner Sun 2000 ausgelesen - nur Fehlermeldungen. Habe schon das Backup von gestern neu eingespielt - gleiche Ergebnis.
                                            Auf meinem PC läuft das gleiche Script - ohne Probleme - alle Werte werden angezeigt.
                                            Hat jemand eine Idee????

                                            Hier Teile des Protokolls
                                            avascript.0
                                            2023-09-01 15:50:03.304 warn script.js.Huawei_Sun: Error received reading address 38200 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:49:58.303 warn script.js.Huawei_Sun: Error received reading address 37700 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:49:53.302 warn script.js.Huawei_Sun: Error received reading address 37100 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:49:48.303 warn script.js.Huawei_Sun: Error received reading address 37000 from id: 1 with error: undefined

                                            admin.0
                                            2023-09-01 15:49:46.330 info <== Disconnect system.user.admin from ::ffff:192.168.178.99 javascript

                                            admin.0
                                            2023-09-01 15:49:46.330 info <== Disconnect system.user.admin from ::ffff:192.168.178.99 javascript

                                            admin.0
                                            2023-09-01 15:49:45.445 info ==> Connected system.user.admin from ::ffff:192.168.178.99

                                            javascript.0
                                            2023-09-01 15:49:43.302 warn script.js.Huawei_Sun: Error received reading address 32000 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:49:38.302 warn script.js.Huawei_Sun: Error received reading address 38200 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:49:33.302 warn script.js.Huawei_Sun: Error received reading address 37700 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:49:28.302 warn script.js.Huawei_Sun: Error received reading address 37100 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:49:23.301 warn script.js.Huawei_Sun: Error received reading address 37000 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:49:18.301 warn script.js.Huawei_Sun: Error received reading address 32000 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:49:13.301 warn script.js.Huawei_Sun: Error received reading address 47081 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:49:08.301 warn script.js.Huawei_Sun: Error received reading address 38400 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:49:03.301 warn script.js.Huawei_Sun: Error received reading address 38300 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:48:58.301 warn script.js.Huawei_Sun: Error received reading address 37800 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:48:53.301 warn script.js.Huawei_Sun: Error received reading address 30000 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:48:48.300 warn script.js.Huawei_Sun: Error received reading address 38200 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:48:43.300 warn script.js.Huawei_Sun: Error received reading address 37700 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:48:38.300 warn script.js.Huawei_Sun: Error received reading address 37100 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:48:33.299 warn script.js.Huawei_Sun: Error received reading address 37000 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:48:28.299 warn script.js.Huawei_Sun: Error received reading address 32000 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:48:23.299 warn script.js.Huawei_Sun: Error received reading address 38200 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:48:18.299 warn script.js.Huawei_Sun: Error received reading address 37700 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:48:13.299 warn script.js.Huawei_Sun: Error received reading address 37100 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:48:08.299 warn script.js.Huawei_Sun: Error received reading address 37000 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:48:03.299 warn script.js.Huawei_Sun: Error received reading address 32000 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:47:58.298 warn script.js.Huawei_Sun: Error received reading address 38200 from id: 1 with error: undefined

                                            javascript.0
                                            2023-09-01 15:47:53.298 warn script.js.Huawei_Sun: Error received reading address 37700 from id: 1 with error: undefined

                                            J 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            927
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

                                            59
                                            471
                                            80428
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo