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

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Huawei Sun2000 & ioBroker via JS script funktioniert

    This topic has been deleted. Only users with topic management privileges can see it.
    • M
      MrLee @Chris_B last edited by MrLee

      @chris_b
      Moin!

      Kamen zyklisch...aber, vielleicht für alle interressant:
      das Script kann nur auf Instanz 0 laufen....sonst legt er Daten unter.0 und die anderen Daten unter .2 (in meinem Falle) ab.

      Ip-Adresse war nicht mein Problem...die RS485 Adressen hatten mich etwas gesuche gekostet...:-)

      Vielen Dank trotzdem fürs kümmern.
      Werde wohl noch nen Paar erweiterungen einbauen (müssen).

      Kuezer Abgleich was ich gerne zukünftig machen möchte / brauche:

      - String 2 fehlt bei mir in den Daten unter javascript.0.Solarpower.Huawei.Inverter.1.String

      • versuchen, die Informationen schneller zu pollen, oder weniger...zykluszeit von 10-20 sekunden wäre mir wegen Regelung wichtig.

      Vielen Dank nochmal für das Teilen Deines Scriptes!!!

      liebe Grüße
      Mr.Lee

      R C 3 Replies Last reply Reply Quote 0
      • R
        R4 @MrLee last edited by R4

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

        • versuchen, die Informationen schneller zu pollen, oder weniger...zykluszeit von 10-20 sekunden wäre mir wegen Regelung wichtig.

        Ja, schwierig. Du kannst wohl nur selbst schauen, welche von den Daten von

        const RegisterSpacesToReadContinuously
        

        du nicht brauchst und diese dann weg lässt. Dummerweise ist schon der zeitliche Ausleseunterschied bei den drei wichtigen Registerbereichen

        [32000, 116], // Solarpower.Huawei.Inverter.ActivePower: 32080 und Solarpower.Huawei.Inverter.InputPower: 32064
        [37100, 114], // Solarpower.Huawei.Meter.ActivePower: 37113
        [37700, 100], // Solarpower.Huawei.Inverter.Battery.SOC: 37760 und Solarpower.Huawei.Inverter.Battery.ChargeAndDischargePower: 37765
        

        Ursache für fehlerhafte Darstellungen bei lockerer Bewölkung (Hausverbrauch kann dann auch mal 0 sein bis zum nächsten Berechnungsdurchgang...).
        Bei mir sind derzeit 4s ein brauchbares Minimum ohne viele Aussetzer.

        Lösung wäre wohl die Daten direkt aus dem WLAN des WR abzugreifen, da soll es dann schneller gehen.
        Ich bin noch am Überlegen, ob ich diese drei Bereiche öfter = schneller auslesen soll als die anderen (die dann z.B. nur jedes fünfte Mal).

        Ein Forumskollege puffert die Daten eine gewisse Zeit und nimmt dann den Durchschnitt. Das hilft dir aber auch nicht weiter.

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

          @xanon Probiere es bitte nochmals. Aber beachte mein 'ACHTUNG' oben. Im Skript tauchen immer wieder {1} auf, diese sind im Code nicht vorhanden. Irgendwie entstehen die erst im 'Code' Teil des Forums. Ich versuche herauszufinden, weshalb...

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

            @mrlee Deine Bemerkung ist korrekt. Momentan setzt es die javascript Instanz 0 voraus. Könnte man sicher im Skript ändern, weiss aber momentan nicht, wie ich im Skript die Instanz-Nummer herausfinden kann. Hat jemand einen Hinweis? Dann passe ich das an.
            Gruss Christian

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

              @mrlee Zur Frage der Zykluszeit:
              Diese kannst Du in der Funktion

              setInterval(function() ...

              ganz am Ende definieren. Momentan steht dort der Wert 5000 = 5000 ms = 5 sec.
              Da 10 Register Spaces gelesen werden ergibt das eine gesamte Zykluszeit von 50 sec.
              Original war der Wert auf 2000, ann ergeben sich ca. 20 sec. Einfach ausprobieren.

              Evtl. beantwortet das deine Frage.
              Gruss

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

                @chris_b
                Moin!

                Ja, den habe ich schon gefunden...selbst bei 4sec habe ich allerdings noch fehler...
                Überlege eine Aufteilung nach "eiligen" Daten ...alle x Sekunden Register und nicht so eilige...nur jede 5te Runde.
                Hab mich aber ehrlicherweise noch nicht mit den Registern beschäftigt.

                Auf jeden Fall erstmal nen Top Script was mir bei den ersten Schritten massiv hilft! Vielen Dank!

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

                  Moin zusammen,

                  ich teste mich auch gerade dadurch, dass ich die Werte in den ioBroker bekomme. Meine Einstellungen am Dongel sehen so aus:

                  Verbindung Aktivieren (uneingeschränkt)
                  MBUS-Protokoll: MODBUS RTU
                  Transormatorkasten Nr. 1
                  Wicklung Nr. 0
                  MAC-Adressen-Offset 1

                  Wechselrichter Version V100R001C20SPC122
                  MBUS(DC)fi_upgradingsun_db Version V100R001C00SPC320

                  Ich habe noch einen Smartmeter verbaut aber keine Batterie.

                  Das Script sagt mir nun folgende fehler:

                  12:16:23.048	error	javascript.0 (2127) script.js.pv.sun2000: Error: Cannot find module 'modbus-serial'
                  12:16:23.049	error	javascript.0 (2127) at script.js.pv.sun2000:4:17
                  12:16:23.049	error	javascript.0 (2127) at script.js.pv.sun2000:359:3
                  
                  12:16:23.053	error	javascript.0 (2127) script.js.pv.sun2000: TypeError: ModbusRTU is not a constructor
                  12:16:23.054	error	javascript.0 (2127) at script.js.pv.sun2000:5:14
                  12:16:23.054	error	javascript.0 (2127) at script.js.pv.sun2000:359:3
                  

                  Wo finde ich die Modbus Serial? Egal welche Seriennummer ich da eintrage, der Fehler bleibt.

                  M 1 Reply Last reply Reply Quote 0
                  • M
                    MrLee @hussi last edited by

                    @hussi
                    modbus-serial ist ein npm paket was Du in deiner JScript instanz eintragen mußt...steht relativ weit oben in diesm threat...

                    bis denne
                    Mr.Lee

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

                      @mrlee Ahhh gefunden. Danke.

                      1 Reply Last reply Reply Quote 0
                      • H
                        hussi @Alex Warkentin last edited by hussi

                        @alex-warkentin

                        Das Skript läuft bei mir und gibt mir die Werte aus, die du eingetragen hast.
                        Danke dafür!

                        Das Skript liefert mir diese Ergebnisse:

                        inverter.JPG
                        meter.JPG

                        Wenn ich das nun auf meinem Fusionsolar Oberfläche Abgleiche habe ich folgende Ergebnisse abgeleitet:

                        Inverter
                        ActivePower = Aktuller Wert was die PV liefert
                        Input Power = ?
                        DailyEnergyYield = Heutiger Ertrag
                        AccomulatedEnergyYield = Gesamtenergieertrag

                        Meter
                        PositiveActiveEnergy = Positive aktive Energie
                        ReverseActiveEnergy = Negative aktive Energie

                        Was ich noch haben möchte:

                        Importierte Wh
                        Exportierte Wh

                        Das hat doch sicher was mit der positiven und negativen Energie zu tun?
                        Allerdings komme ich nicht darauf.

                        Weiß jemand einen Rat?

                        M 1 Reply Last reply Reply Quote 0
                        • M
                          MrLee @hussi last edited by

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

                          Moin!

                          ich lese die Daten etwas anders...

                          Inverter
                          ActivePower = Aktuller Wert was die PV liefert

                          aktueller Hausverbrauch

                          Input Power = ?

                          Input PV Strings

                          Meter
                          PositiveActiveEnergy = Positive aktive Energie

                          Hier bin ich gerade am Rätseln...gesamtVerbrauch Haus today?
                          Der wäre mir nämlich recht lieb.

                          Was ich noch haben möchte:

                          Importierte Wh
                          Exportierte Wh

                          javascript.0.Solarpower.Derived.GridExportSum
                          und folgende ?

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

                            @mrlee

                            Hier mal gleichzeitig die Werte aus der Weboberfläche zusammen mit dem Inverter und dem Meter aus dem ioBroker.

                            inverter_neu.JPG
                            meter_neu.JPG
                            weboberfläche.JPG

                            Es ist kein normales Haus sondern eine Esso Station. Daher sind die Werte nicht mit einem Einfamilienhaus zu vergleichen.

                            javascript.0.Solarpower.Derived.GridExportSum
                            Woher hast du das?
                            Das habe ich nicht.

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

                              Für Freaks: 😊

                              Ich lade meine Luna scriptgesteuert bevorzugt ab dem Zeitpunkt, bei dem die maximale Leistung des WR (11 kW bei meinem 10KTL - habe 16,6 kWp) ins Haus+Netz gehen kann, denn ab da ist der Akkuladestrom tatsächlich kostenlos (= Überschussenergie im wahrsten Sinn).

                              Wie viel das ist sammle ich (näherungsweise) hiermit:

                              const idPower = "javascript.0.Solarpower.Derived.BatteryFreePower";  // Datenpunkt der "überschüssigen" Ladeleistung [W]
                              const idEnergy = "javascript.0.Solarpower.Derived.BatteryFreeEnergy";  // [kWh]
                              const initialKwh = 0.0; // [kWh] am Anfang
                              var energy = 0;
                               
                              // Datenpunkt für "geschenkte Ladeleisung"
                              createState("javascript.0.Solarpower.Derived.BatteryFreePower", 0,  {read: true, write: true, name: "Battery free charging power", unit: "W"});
                              
                              // Energie-Datenpunkt erzeugen
                              createState(idEnergy, initialKwh, { type: "number", name: "Kostenlose Akkuladeenergie", unit: "kWh" },
                                  () => energy = 1000 * getState(idEnergy).val
                              ); // Anfangswert
                               
                              on({ id: idPower }, function (dp) { // triggert bei jeder Wertänderung
                                  energy = energy + dp.oldState.val * (dp.state.lc - dp.oldState.lc) / 3600000; // [Wh]
                                  setState(idEnergy, Math.round(energy) / 1000, true); // [kWh] mit 3 Nachkommastellen
                              });
                              
                              

                              in function ProcessData() kommt dann noch:

                              // compute free charging power
                                  var FreePower;
                                  var ChargePower = getState("javascript.0.Solarpower.Huawei.Inverter.Battery.ChargeAndDischargePower").val;
                                  if (ChargePower > 0) // Akku lädt (geht auch anders, da gibt's einen extra Registereintrag)
                                  {
                                      FreePower = (PanelPower * 1000) - 11000;
                                      if (FreePower < 0) FreePower = 0; // zu wenig Leistung vom Dach
                                  }
                                  else FreePower = 0; // Akku lädt eh nicht
                                  setState("javascript.0.Solarpower.Derived.BatteryFreePower", FreePower); // [W]
                              

                              Ich lass das in die .csv reinschreiben.
                              Wenn man es dann auf 0 zurücksetzen lassen will muss natürlich nach

                              // one minute before midnight - perform housekeeping actions
                              [...]
                              SolarPowerLogging();"

                              noch:

                              // reset BatteryFreeEnergy for next day
                              setState("javascript.0.Solarpower.Derived.BatteryFreeEnergy", 0);
                              energy = 0;
                              

                              Dank insbesondere an @Chris_B

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

                                @hussi
                                Ich habe das Ganze mit Hilfe dieses Bildes umgesetzt:
                                562698cb-619b-4a1c-82c1-3ff5968a0e11-grafik.png
                                Das habe ich irgendwo im Netz gefunden. Die Variable unter 'Derived' (abgeleitet) sind (unter anderem) nach dieser Abbildung erstellt. Die vom Netz importierte / exportierte Leistung an einem Tag findest Du unter:

                                javascript.0.Solarpower.Derived.GridExportToday
                                javascript.0.Solarpower.Derived.GridImportToday

                                Gruss
                                Christian

                                H 1 Reply Last reply Reply Quote 0
                                • P
                                  ple last edited by

                                  Hallo zusammen,
                                  kurze Frage, NodeRed nutze ich gerade nur um Daten zu lesen, klappt soweit ganz gut.
                                  Jetzt zu Zeiten von Tibber wollte ich gerne meine PV mal abschalten oder reduzieren, damit voll Netzbezug machen kann.
                                  Hat es schon mal einer geschafft die Analge via Modbus zu drosseln oder gar abzuschalten? Heute wird der Strom bei Tibber bei -44 Cent liegen, daher meine Frage.

                                  Gruß und DAnke

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

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

                                    javascript.0.Solarpower.Derived.GridExportToday
                                    javascript.0.Solarpower.Derived.GridImportToday

                                    Hallo Christian,

                                    die Punkte habe ich nicht.

                                    Das Bild verstehe ich, glaube ich. Aber ich habe (noch) keine Batterie. Also kann ich ja nicht "Portal Yield today" errechnen.

                                    Ich habe hier einen eigenen Thread eröffnet. Ich glaube das stört hier sonst.

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

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

                                      Ich habe das Skript nochmals etwas erweitert:
                                      Jetzt werden auch jeden Tag 1 Minute vor Mitternacht die Tagesdaten in die Datei /opt/iobroker/iobroker-data/SolarpowerLog.csv geschrieben. Pro Tag werden folgende Daten geschrieben:

                                      Danke, gestern hab ich das Script mit dem neuen WR in Betrieb genommen - läuft einwandfrei.

                                      Weil die Frage zu den Optimierern schon gekommen ist, die wären in folgender lib schon mit integriert => https://github.com/wlcrs/huawei-solar-lib

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

                                        @chris_b
                                        Für das Schreiben der Log-Datei würde ich noch vorschlagen, die Nachkommastellen-Punkte in Kommata umzuwandeln, also so in der Art:

                                        string = currDate + ";" + log1.toFixed(2).replace('.',',') + ";" + log2.toFixed(2).replace('.',',') ...
                                        

                                        Ansonsten habe ich die Register nach "Wichtigkeit" sortiert

                                        // These register spaces need to be read:
                                        const RegisterSpacesToReadContinuously = [[32000, 116], // Inverter.ActivePower: 32080, Inverter.InputPower: 32064
                                                                                  [37100, 114], // Meter.ActivePower: 37113
                                                                                  [37700, 100], // Inverter.Battery.SOC: 37760, Inverter.Battery.ChargeAndDischargePower: 37765
                                                                                  [47075, 10],  // MaximumChargingPower,...
                                                                                  [37000, 68],  // Batterystack,...
                                                                                  [37800, 100], // Batterystack
                                                                                  [38200, 100], // Batterystack
                                                                                  [38300, 100], // Batterystack
                                                                                  [38400, 100], // Batterystack
                                                                                  [30000, 81]   // --> ProcessDeviceInfo()
                                        //                                          [35300, 40] // Inverter.ActiveAdjustement.* 
                                                                                  ];
                                        

                                        und lasse nur die ersten 4 regelmäßig auslesen und nur alle 50 Runden mal (~ jede Viertel Stunde) alle zusammen. Weil ich nur eine Batterie habe ergibt das bei mir also alle 16s frische Daten (immerhin...).

                                        C M 2 Replies Last reply Reply Quote 0
                                        • C
                                          Chris_B @R4 last edited by

                                          @r4
                                          Interessanter Input!
                                          Zu 1: Es gibt da die kleinen, subtilen Unterschiede zwischen Deutschland und der Schweiz... 😊 Und wir hier in der Schweiz verwenden tatsächlich einen Punkt für die Nachkommastellen von Zahlen (das weiss bspw. auch Excel und Windows im Allgemeinen). In diesem Sinn wäre diese Änderung für mich falsch. Nach meiner Meinung sollte das durch die Ländereinstellungen im iobroker gelöst sein..
                                          Zu 2) Das wollte ich auch noch in Angriff nehmen. Guter Lösungsvorschlag; verringert die Kommunikation auf ein 'sinnvolles' Mass. Werde ich auch umsetzen.
                                          Danke für den Input
                                          Christian

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

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

                                            @r4
                                            Interessanter Input!
                                            Zu 1: ... Nach meiner Meinung sollte das durch die Ländereinstellungen im iobroker gelöst sein..

                                            Muss ich mir mal anschauen (bin neu in diesem Thema).
                                            (Hab eh noch Probleme mit der Uhrzeit / Zeitzone... da wird meist die richtige angezeigt, z.B. in der Console, aber ich muss schedule("59 21 * * *") angeben um 23:59 Uhr zu triggern 🤷‍♂️ )

                                            Im Übrigen... so funktioniert es besser:

                                            string = log1.toFixed(2) + ";" + log2.toFixed(2) + ";" + log3.toFixed(2) + ...
                                            string = currDate + ";" + string.replaceAll(".",",");
                                            
                                            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

                                            915
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            60
                                            477
                                            90227
                                            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