Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. ecoflow-connector-Script zur dynamischen Leistungsanpassung

NEWS

  • Wartung am 15.11. – Forum ab 22:00 Uhr nicht erreichbar
    BluefoxB
    Bluefox
    11
    2
    197

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    7.9k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.7k

ecoflow-connector-Script zur dynamischen Leistungsanpassung

ecoflow-connector-Script zur dynamischen Leistungsanpassung

Scheduled Pinned Locked Moved JavaScript
1.6k Posts 127 Posters 741.1k Views 127 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • W Waly_de

    @sirdir sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

    Es ist schon seltsam. Die 1.1.6.1 funktioniert jeden Tag bis 1 Uhr wo ich die Batterie wieder auflade und nix einspeise, aber morgens um 7 wo wieder eingespeist werden sollte tut das script einfach nix mehr. Ein Neustart hilft nix, aber wenn ch das alte Script starte funktioniert’s und wenn ich dann zum 1.1.6.1 zurück gehe geht das auch wieder… Hab jetzt endlich gesehen was die mlog funktion tut und kann das vielleicht morgen anschauen… wobei ich keine Lust habe da wieder um 7 rumzudebuggen, vielleicht lass ich das alte Script laufen…

    Das Problem hat bisher keiner reportet. Du sagst du lädst um 1. stellst du dann das script mit regulate state ab? Keine Meldungen im Log?

    @sirdir sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

    Aber um noch etwas sinnvolles beizutragen, da noch niemand davon geschrieben hat und Waly das Update ja vielleicht nicht bekommen hat, wer weiss. Es gibt die neue Funktion ‘Feed-in control’, die festlegt, ob bei vollem Akku die ganze Solarleistung eingespeist werden soll (control off) oder nur was eingestellt ist (control on):

    Oh, cool. Nein, ich hab das Update nicht bekommen. 0801 als payload? Das ist wirklich schräg.... ich bau es mal in die Writeables...

    S Offline
    S Offline
    sirdir
    wrote on last edited by
    #756

    @waly_de Nein ich änder nichts an deinem Script. Mein ‘Zählersimulator’ meldet einfach zwischen 1 und 7 Uhr, dass nix eingespeist werden muss. Hat immer funktioniert bis ich 1.1.6.1 installiert habe. Kann aber auch Zufall sein… Nein im Log hab ich gar nichts gefunden, aber im Log sieht man ja auch nicht soo viel, wenn logM nicht an ist(warum hast du das eigentlich aufgetrennt mit logM und debug? Debug steuer ich einen externen state, mit logM geht das natürlich nicht. Naja könnte es ja auch ändern im script.

    W 1 Reply Last reply
    0
    • S sirdir

      @waly_de Nein ich änder nichts an deinem Script. Mein ‘Zählersimulator’ meldet einfach zwischen 1 und 7 Uhr, dass nix eingespeist werden muss. Hat immer funktioniert bis ich 1.1.6.1 installiert habe. Kann aber auch Zufall sein… Nein im Log hab ich gar nichts gefunden, aber im Log sieht man ja auch nicht soo viel, wenn logM nicht an ist(warum hast du das eigentlich aufgetrennt mit logM und debug? Debug steuer ich einen externen state, mit logM geht das natürlich nicht. Naja könnte es ja auch ändern im script.

      W Offline
      W Offline
      Waly_de
      wrote on last edited by
      #757

      @sirdir mlog war eigentlich nur für mich gedacht, damit ich gezielt Stellen debugen kann, ohne zugemüllt zu werden 😉

      Zu deinem Problem fällt mir so leider nichts mehr ein. Guck halt mal, ob das Script überhaupt noch was macht, oder ob es vielleicht vom Adapter gestoppt wurde.
      Mit Debug oder mlog sollte das ja einfach festzustellen sein.

      Kannst Du vielleicht mal testen, ob das neue Writeable funktioniert? Ich hab ja leider noch kein Update bekommen.

      S 1 Reply Last reply
      0
      • W Waly_de

        @sirdir mlog war eigentlich nur für mich gedacht, damit ich gezielt Stellen debugen kann, ohne zugemüllt zu werden 😉

        Zu deinem Problem fällt mir so leider nichts mehr ein. Guck halt mal, ob das Script überhaupt noch was macht, oder ob es vielleicht vom Adapter gestoppt wurde.
        Mit Debug oder mlog sollte das ja einfach festzustellen sein.

        Kannst Du vielleicht mal testen, ob das neue Writeable funktioniert? Ich hab ja leider noch kein Update bekommen.

        S Offline
        S Offline
        sirdir
        wrote on last edited by
        #758

        @waly_de ja vielleicht schau ich heut nacht/morgen früh, aber vielleicht bin ich auch zu faul. An gestopptem Script kann's nicht liegen, da ein neustert nicht hilft, seltsamerweise.
        Das writeable ist 0_userdata.0.ecoflow.app_device_property_xxx.data.InverterHeartbeat.feedPriority? Oder hab ich was übersehen? Der Status wird korrekt angezeigt, aber wenn ich ihn dort überschreibe ändert sich sich nichts in der App.

        W 1 Reply Last reply
        0
        • S sirdir

          @waly_de ja vielleicht schau ich heut nacht/morgen früh, aber vielleicht bin ich auch zu faul. An gestopptem Script kann's nicht liegen, da ein neustert nicht hilft, seltsamerweise.
          Das writeable ist 0_userdata.0.ecoflow.app_device_property_xxx.data.InverterHeartbeat.feedPriority? Oder hab ich was übersehen? Der Status wird korrekt angezeigt, aber wenn ich ihn dort überschreibe ändert sich sich nichts in der App.

          W Offline
          W Offline
          Waly_de
          wrote on last edited by Waly_de
          #759

          @sirdir ne die writeables stehen ja unter
          0_userdata.0.ecoflow.app_XXXXX_XXXXX_thing_property_set.writeables...

          sollte feed_priority heissen

          S 1 Reply Last reply
          0
          • W Waly_de

            @sirdir ne die writeables stehen ja unter
            0_userdata.0.ecoflow.app_XXXXX_XXXXX_thing_property_set.writeables...

            sollte feed_priority heissen

            S Offline
            S Offline
            sirdir
            wrote on last edited by
            #760

            @waly_de d'oh, hab ich nicht gefunden… war aber auch sehr in Eile. Ja, hab's jetzt gesehen, funktioniert.

            1 Reply Last reply
            0
            • W Waly_de

              @karo2204

              sorry... mein Fehler. Hier der Fix:

              Modul Quelltext ist jetzt im Eingansbeitrag 
              
              K Offline
              K Offline
              karo2204
              wrote on last edited by
              #761

              @waly_de Mmh, heute Nachmittag hat alles noch gut funktioniert, und jetzt arbeitet das Script nicht mehr richtig 😞

              In den Logs bekomme ich nach Neustart von iob folgendes:

              State value to set for "0_userdata.0.ecoflow.Settings.ConfigData" has to be one of type "string", "number", "boolean" but received type "object"

              ConfigData ist auch rot in den Objects.

              Was kann ich machen? Ich war so happy, dass es funktioniert.

              ioBroker
              Tibber
              Ecoflow Powerstream & Delta Max 2000

              1 Reply Last reply
              0
              • K karo2204

                @waly_de said in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

                                                                                                                                            //*************************************************************                                                                                                                                                                            // Tibber Modul                                                                                                                                                                            //*************************************************************                                                                                                                                                                            // Schaltet die Regelung der Powerstation ab, wenn der Strom billig ist                                                                                                                                                                             // und einen beliebigen Schalter zum Aktivieren der AC-Ladung ein, bis die Batterie                                                                                                                                                                             // den durch der "BatMax" festgelegten Ladestand in % erreicht hat                                                                                                                                                                            //                                                                                                                                                                             // Diese Parameter aus dem Hauptscript sind wichtig:                                                                                                                                                                            // RegulationOffPower: -2 // Wird die Regulation per State abgestellt, wird die Einspeiseleistung des ersten Powerstreams auf diesen Wert gesetzt (-1 = keine Änderung, -2 = Batterie Priomodus)                                                                                                                                                                            // RegulationState: "Regulate" // Erzeugt der State zum Ein und Aus-Schalten der Regulation.                                                                                                                                                                            //                                                                                                                                                                            // Das Script versucht selbst die ID's für den TibberStatus und den Batteriestand zu ermitteln.                                                                                                                                                                            // Wenn das nicht klappt bitte einfach die richtigen ID's hinter "batSocID" und "tibberID" angeben.                                                                                                                                                                            //                                                                                                                                                                            //*************************************************************                                                                                                                                                                                                                                                                                                                                                         //*************************************************************                                                                                                                                                                            // Konfiguration laden, wenn nicht im Originalscript eingefügt                                                                                                                                                                            //*************************************************************                                                                                                                                                                            var ConfigData = {                                                                                                                                                                                statesPrefix: '0_userdata.0.ecoflow',                                                                                                                                                                                RegulationState: "Regulate"                                                                                                                                                                            }                                                                                                                                                                            if (typeof ConfigData.email === 'undefined') {                                                                                                                                                                                if (getState("0_userdata.0.ecoflow.Settings.ConfigData").val.email !== undefined) {                                                                                                                                                                                    ConfigData = getState("0_userdata.0.ecoflow.Settings.ConfigData").val;                                                                                                                                                                                }                                                                                                                                                                            }                                                                                                                                                                                                                                                                                                                                                         /***************************************                                                                                                                                                                            **********  YOUR DATA HERE  ************                                                                                                                                                                             ****************************************/                                                                                                                                                                            var tibberConfig = {                                                                                                                                                                                BatMax: 99,                                  //Bei diesem Ladestand stoppt die AC-Ladung und das Script wird wieder eingeschaltet                                                                                                                                                                                 BatMin: 95,                                  //Der Ladestand der Batterie muss kleiner sein als BatMin , damit der Akku per AC-Ladung geladen wird                                                                                                                                                                                 SwitchID: "sonoff.0.NOUS-DVES_F0A844.POWER", //ID des Schalters, der die AC-Ladung einschaltet. "true" und "false" werden gesetzt                                                                                                                                                                                LevelToSwitch: [                             //Hier die Werte definieren, bei denen die AC-Ladung eingeschaltet werden soll                                                                                                                                                                                    //"NORMAL",                                                                                                                                                                                    "CHEAP",                                 //Einkommentieren falls gewüscht                                                                                                                                                                                     "VERY_CHEAP"                                                                                                                                                                                ],                                                                                                                                                                            }                                                                                                                                                                            //***************************************/                                                                                                                                                                            // Nur angeben, wenn automatische Ermittlung fehlschlägt                                                                                                                                                                            //***************************************/                                                                                                                                                                            let batSocID = getState(ConfigData.statesPrefix + ".Settings.Tibber.tibberBatSocID").val                                                                                                                                                                            let tibberID = getState(ConfigData.statesPrefix + ".Settings.Tibber.tibberID").val                                                                                                                                                                            //***************************************/                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      var idOK = false                                                                                                                                                                            if (!batSocID || !tibberID) {                                                                                                                                                                                log("Versuche die IDs für Tibber und Batterielevel zu finden")                                                                                                                                                                                $("tibberlink.*.Homes.*.CurrentPrice.level").each(function (id, i) {                                                                                                                                                                                    tibberID = id                                                                                                                                                                                    createState(ConfigData.statesPrefix + ".Settings.Tibber.tibberID", tibberID, false)                                                                                                                                                                                    log("TibberID gefunden und gespeichert:" + id)                                                                                                                                                                                })                                                                                                                                                                                $(ConfigData.statesPrefix + ".app_device_property_*.data.InverterHeartbeat.batSoc").each(function (id, i) {                                                                                                                                                                                    if (getState(id).val > 0) {                                                                                                                                                                                        batSocID = id                                                                                                                                                                                        createState(ConfigData.statesPrefix + ".Settings.Tibber.tibberBatSocID", batSocID, false)                                                                                                                                                                                        log("batSocID gefunden und gespeichert:" + id)                                                                                                                                                                                    }                                                                                                                                                                                })                                                                                                                                                                                if (!batSocID || !tibberID) {                                                                                                                                                                                    log("Fehler bei der Ermittlung der IDs. Bitte händisch ins Script eintragen", 'error')                                                                                                                                                                                } else {                                                                                                                                                                                    idOK = true                                                                                                                                                                                }                                                                                                                                                                            } else {                                                                                                                                                                                idOK = true                                                                                                                                                                            }                                                                                                                                                                            if (idOK) {                                                                                                                                                                                checkTibber()                                                                                                                                                                                on({ id: tibberID, change: "ne" }, function (obj) {                                                                                                                                                                                    //log("Tibber Modul. tibberID Event:" + obj.state.val)                                                                                                                                                                                    checkTibber()                                                                                                                                                                                });                                                                                                                                                                                on({ id: batSocID, change: "ne" }, function (obj) {                                                                                                                                                                                    //log("Tibber Modul. batSocID Event:" + obj.state.val + "%")                                                                                                                                                                                    checkTibber()                                                                                                                                                                                });                                                                                                                                                                            }                                                                                                                                                                            function checkTibber() {                                                                                                                                                                                if (tibberID && batSocID) {                                                                                                                                                                                    const RegulateID = ConfigData.statesPrefix + "." + ConfigData.RegulationState                                                                                                                                                                                    let priceLevel = getState(tibberID).val;                                                                                                                                                                                    let batsoc = Number(getState(batSocID).val)                                                                                                                                                                                    let OldRegulate = toBoolean(getState(RegulateID).val)                                                                                                                                                                                    //log("Tibber Preislevel: " + priceLevel + " OldRegulate: " + OldRegulate + " batsoc: " + (batsoc))                                                                                                                                                                                    if ((tibberConfig.LevelToSwitch.includes(priceLevel))) {                                                                                                                                                                                        if (OldRegulate) {                                                                                                                                                                                            if (batsoc <= tibberConfig.BatMin) {                                                                                                                                                                                                setState(RegulateID, false);  // Regulierung aus                                                                                                                                                                                                setState(tibberConfig.SwitchID, true) //Schalter einschalten                                                                                                                                                                                                log("Script abgeschaltet AC-Ladung Ein, weil priceLevel:" + priceLevel + " batsoc:" + batsoc + "%")                                                                                                                                                                                            }                                                                                                                                                                                        } else {                                                                                                                                                                                            if (batsoc >= tibberConfig.BatMax) {                                                                                                                                                                                                setState(RegulateID, true);  // Regulierung an                                                                                                                                                                                                setState(tibberConfig.SwitchID, false) //Schalter ausschalten                                                                                                                                                                                                log(" Batterie bei BatMax. Script eingeschaltet AC-Ladung Aus. priceLevel:" + priceLevel + " batsoc:" + batsoc + "%")                                                                                                                                                                                            }                                                                                                                                                                                        }                                                                                                                                                                                    } else {                                                                                                                                                                                        if (!OldRegulate) {                                                                                                                                                                                            setState(RegulateID, true);  // Regulierung an                                                                                                                                                                                            setState(tibberConfig.SwitchID, false) //Schalter ausschalten                                                                                                                                                                                            log("Script eingeschaltet AC-Ladung Aus. priceLevel:" + priceLevel + " batsoc:" + batsoc + "%")                                                                                                                                                                                        }                                                                                                                                                                                    }                                                                                                                                                                                } else {                                                                                                                                                                                    //log("checkTibber skip. batsocID und/oder tibberID fehlen.")                                                                                                                                                                                }                                                                                                                                                                            }                                                                                                                                                                            //*************************************************************                                            
                

                Ich bekomme hier den Fehler angezeigt:

                javascript.0 (52431) script.js.Ecoflow-Tibber: TypeError: Cannot read properties of null (reading 'email')
                07:11:14.323	error	javascript.0 (52431) at script.js.Ecoflow-Tibber:25:65
                07:11:14.324	error	javascript.0 (52431) at script.js.Ecoflow-Tibber:119:3
                

                Was kann ich da machen?

                K Offline
                K Offline
                karo2204
                wrote on last edited by
                #762

                @karo2204 said in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

                @waly_de said in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

                                                                                                                                            //*************************************************************                                                                                                                                                                            // Tibber Modul                                                                                                                                                                            //*************************************************************                                                                                                                                                                            // Schaltet die Regelung der Powerstation ab, wenn der Strom billig ist                                                                                                                                                                             // und einen beliebigen Schalter zum Aktivieren der AC-Ladung ein, bis die Batterie                                                                                                                                                                             // den durch der "BatMax" festgelegten Ladestand in % erreicht hat                                                                                                                                                                            //                                                                                                                                                                             // Diese Parameter aus dem Hauptscript sind wichtig:                                                                                                                                                                            // RegulationOffPower: -2 // Wird die Regulation per State abgestellt, wird die Einspeiseleistung des ersten Powerstreams auf diesen Wert gesetzt (-1 = keine Änderung, -2 = Batterie Priomodus)                                                                                                                                                                            // RegulationState: "Regulate" // Erzeugt der State zum Ein und Aus-Schalten der Regulation.                                                                                                                                                                            //                                                                                                                                                                            // Das Script versucht selbst die ID's für den TibberStatus und den Batteriestand zu ermitteln.                                                                                                                                                                            // Wenn das nicht klappt bitte einfach die richtigen ID's hinter "batSocID" und "tibberID" angeben.                                                                                                                                                                            //                                                                                                                                                                            //*************************************************************                                                                                                                                                                                                                                                                                                                                                         //*************************************************************                                                                                                                                                                            // Konfiguration laden, wenn nicht im Originalscript eingefügt                                                                                                                                                                            //*************************************************************                                                                                                                                                                            var ConfigData = {                                                                                                                                                                                statesPrefix: '0_userdata.0.ecoflow',                                                                                                                                                                                RegulationState: "Regulate"                                                                                                                                                                            }                                                                                                                                                                            if (typeof ConfigData.email === 'undefined') {                                                                                                                                                                                if (getState("0_userdata.0.ecoflow.Settings.ConfigData").val.email !== undefined) {                                                                                                                                                                                    ConfigData = getState("0_userdata.0.ecoflow.Settings.ConfigData").val;                                                                                                                                                                                }                                                                                                                                                                            }                                                                                                                                                                                                                                                                                                                                                         /***************************************                                                                                                                                                                            **********  YOUR DATA HERE  ************                                                                                                                                                                             ****************************************/                                                                                                                                                                            var tibberConfig = {                                                                                                                                                                                BatMax: 99,                                  //Bei diesem Ladestand stoppt die AC-Ladung und das Script wird wieder eingeschaltet                                                                                                                                                                                 BatMin: 95,                                  //Der Ladestand der Batterie muss kleiner sein als BatMin , damit der Akku per AC-Ladung geladen wird                                                                                                                                                                                 SwitchID: "sonoff.0.NOUS-DVES_F0A844.POWER", //ID des Schalters, der die AC-Ladung einschaltet. "true" und "false" werden gesetzt                                                                                                                                                                                LevelToSwitch: [                             //Hier die Werte definieren, bei denen die AC-Ladung eingeschaltet werden soll                                                                                                                                                                                    //"NORMAL",                                                                                                                                                                                    "CHEAP",                                 //Einkommentieren falls gewüscht                                                                                                                                                                                     "VERY_CHEAP"                                                                                                                                                                                ],                                                                                                                                                                            }                                                                                                                                                                            //***************************************/                                                                                                                                                                            // Nur angeben, wenn automatische Ermittlung fehlschlägt                                                                                                                                                                            //***************************************/                                                                                                                                                                            let batSocID = getState(ConfigData.statesPrefix + ".Settings.Tibber.tibberBatSocID").val                                                                                                                                                                            let tibberID = getState(ConfigData.statesPrefix + ".Settings.Tibber.tibberID").val                                                                                                                                                                            //***************************************/                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      var idOK = false                                                                                                                                                                            if (!batSocID || !tibberID) {                                                                                                                                                                                log("Versuche die IDs für Tibber und Batterielevel zu finden")                                                                                                                                                                                $("tibberlink.*.Homes.*.CurrentPrice.level").each(function (id, i) {                                                                                                                                                                                    tibberID = id                                                                                                                                                                                    createState(ConfigData.statesPrefix + ".Settings.Tibber.tibberID", tibberID, false)                                                                                                                                                                                    log("TibberID gefunden und gespeichert:" + id)                                                                                                                                                                                })                                                                                                                                                                                $(ConfigData.statesPrefix + ".app_device_property_*.data.InverterHeartbeat.batSoc").each(function (id, i) {                                                                                                                                                                                    if (getState(id).val > 0) {                                                                                                                                                                                        batSocID = id                                                                                                                                                                                        createState(ConfigData.statesPrefix + ".Settings.Tibber.tibberBatSocID", batSocID, false)                                                                                                                                                                                        log("batSocID gefunden und gespeichert:" + id)                                                                                                                                                                                    }                                                                                                                                                                                })                                                                                                                                                                                if (!batSocID || !tibberID) {                                                                                                                                                                                    log("Fehler bei der Ermittlung der IDs. Bitte händisch ins Script eintragen", 'error')                                                                                                                                                                                } else {                                                                                                                                                                                    idOK = true                                                                                                                                                                                }                                                                                                                                                                            } else {                                                                                                                                                                                idOK = true                                                                                                                                                                            }                                                                                                                                                                            if (idOK) {                                                                                                                                                                                checkTibber()                                                                                                                                                                                on({ id: tibberID, change: "ne" }, function (obj) {                                                                                                                                                                                    //log("Tibber Modul. tibberID Event:" + obj.state.val)                                                                                                                                                                                    checkTibber()                                                                                                                                                                                });                                                                                                                                                                                on({ id: batSocID, change: "ne" }, function (obj) {                                                                                                                                                                                    //log("Tibber Modul. batSocID Event:" + obj.state.val + "%")                                                                                                                                                                                    checkTibber()                                                                                                                                                                                });                                                                                                                                                                            }                                                                                                                                                                            function checkTibber() {                                                                                                                                                                                if (tibberID && batSocID) {                                                                                                                                                                                    const RegulateID = ConfigData.statesPrefix + "." + ConfigData.RegulationState                                                                                                                                                                                    let priceLevel = getState(tibberID).val;                                                                                                                                                                                    let batsoc = Number(getState(batSocID).val)                                                                                                                                                                                    let OldRegulate = toBoolean(getState(RegulateID).val)                                                                                                                                                                                    //log("Tibber Preislevel: " + priceLevel + " OldRegulate: " + OldRegulate + " batsoc: " + (batsoc))                                                                                                                                                                                    if ((tibberConfig.LevelToSwitch.includes(priceLevel))) {                                                                                                                                                                                        if (OldRegulate) {                                                                                                                                                                                            if (batsoc <= tibberConfig.BatMin) {                                                                                                                                                                                                setState(RegulateID, false);  // Regulierung aus                                                                                                                                                                                                setState(tibberConfig.SwitchID, true) //Schalter einschalten                                                                                                                                                                                                log("Script abgeschaltet AC-Ladung Ein, weil priceLevel:" + priceLevel + " batsoc:" + batsoc + "%")                                                                                                                                                                                            }                                                                                                                                                                                        } else {                                                                                                                                                                                            if (batsoc >= tibberConfig.BatMax) {                                                                                                                                                                                                setState(RegulateID, true);  // Regulierung an                                                                                                                                                                                                setState(tibberConfig.SwitchID, false) //Schalter ausschalten                                                                                                                                                                                                log(" Batterie bei BatMax. Script eingeschaltet AC-Ladung Aus. priceLevel:" + priceLevel + " batsoc:" + batsoc + "%")                                                                                                                                                                                            }                                                                                                                                                                                        }                                                                                                                                                                                    } else {                                                                                                                                                                                        if (!OldRegulate) {                                                                                                                                                                                            setState(RegulateID, true);  // Regulierung an                                                                                                                                                                                            setState(tibberConfig.SwitchID, false) //Schalter ausschalten                                                                                                                                                                                            log("Script eingeschaltet AC-Ladung Aus. priceLevel:" + priceLevel + " batsoc:" + batsoc + "%")                                                                                                                                                                                        }                                                                                                                                                                                    }                                                                                                                                                                                } else {                                                                                                                                                                                    //log("checkTibber skip. batsocID und/oder tibberID fehlen.")                                                                                                                                                                                }                                                                                                                                                                            }                                                                                                                                                                            //*************************************************************                                            
                

                Ich bekomme hier den Fehler angezeigt:

                javascript.0 (52431) script.js.Ecoflow-Tibber: TypeError: Cannot read properties of null (reading 'email')
                07:11:14.323	error	javascript.0 (52431) at script.js.Ecoflow-Tibber:25:65
                07:11:14.324	error	javascript.0 (52431) at script.js.Ecoflow-Tibber:119:3
                

                Was kann ich da machen?

                ioBroker
                Tibber
                Ecoflow Powerstream & Delta Max 2000

                W 1 Reply Last reply
                0
                • W Offline
                  W Offline
                  Waly_de
                  wrote on last edited by
                  #763

                  @sirdir sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

                  @waly_de d'oh, hab ich nicht gefunden… war aber auch sehr in Eile. Ja, hab's jetzt gesehen, funktioniert.

                  Top! Danke

                  1 Reply Last reply
                  0
                  • K karo2204

                    @karo2204 said in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

                    @waly_de said in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

                                                                                                                                                //*************************************************************                                                                                                                                                                            // Tibber Modul                                                                                                                                                                            //*************************************************************                                                                                                                                                                            // Schaltet die Regelung der Powerstation ab, wenn der Strom billig ist                                                                                                                                                                             // und einen beliebigen Schalter zum Aktivieren der AC-Ladung ein, bis die Batterie                                                                                                                                                                             // den durch der "BatMax" festgelegten Ladestand in % erreicht hat                                                                                                                                                                            //                                                                                                                                                                             // Diese Parameter aus dem Hauptscript sind wichtig:                                                                                                                                                                            // RegulationOffPower: -2 // Wird die Regulation per State abgestellt, wird die Einspeiseleistung des ersten Powerstreams auf diesen Wert gesetzt (-1 = keine Änderung, -2 = Batterie Priomodus)                                                                                                                                                                            // RegulationState: "Regulate" // Erzeugt der State zum Ein und Aus-Schalten der Regulation.                                                                                                                                                                            //                                                                                                                                                                            // Das Script versucht selbst die ID's für den TibberStatus und den Batteriestand zu ermitteln.                                                                                                                                                                            // Wenn das nicht klappt bitte einfach die richtigen ID's hinter "batSocID" und "tibberID" angeben.                                                                                                                                                                            //                                                                                                                                                                            //*************************************************************                                                                                                                                                                                                                                                                                                                                                         //*************************************************************                                                                                                                                                                            // Konfiguration laden, wenn nicht im Originalscript eingefügt                                                                                                                                                                            //*************************************************************                                                                                                                                                                            var ConfigData = {                                                                                                                                                                                statesPrefix: '0_userdata.0.ecoflow',                                                                                                                                                                                RegulationState: "Regulate"                                                                                                                                                                            }                                                                                                                                                                            if (typeof ConfigData.email === 'undefined') {                                                                                                                                                                                if (getState("0_userdata.0.ecoflow.Settings.ConfigData").val.email !== undefined) {                                                                                                                                                                                    ConfigData = getState("0_userdata.0.ecoflow.Settings.ConfigData").val;                                                                                                                                                                                }                                                                                                                                                                            }                                                                                                                                                                                                                                                                                                                                                         /***************************************                                                                                                                                                                            **********  YOUR DATA HERE  ************                                                                                                                                                                             ****************************************/                                                                                                                                                                            var tibberConfig = {                                                                                                                                                                                BatMax: 99,                                  //Bei diesem Ladestand stoppt die AC-Ladung und das Script wird wieder eingeschaltet                                                                                                                                                                                 BatMin: 95,                                  //Der Ladestand der Batterie muss kleiner sein als BatMin , damit der Akku per AC-Ladung geladen wird                                                                                                                                                                                 SwitchID: "sonoff.0.NOUS-DVES_F0A844.POWER", //ID des Schalters, der die AC-Ladung einschaltet. "true" und "false" werden gesetzt                                                                                                                                                                                LevelToSwitch: [                             //Hier die Werte definieren, bei denen die AC-Ladung eingeschaltet werden soll                                                                                                                                                                                    //"NORMAL",                                                                                                                                                                                    "CHEAP",                                 //Einkommentieren falls gewüscht                                                                                                                                                                                     "VERY_CHEAP"                                                                                                                                                                                ],                                                                                                                                                                            }                                                                                                                                                                            //***************************************/                                                                                                                                                                            // Nur angeben, wenn automatische Ermittlung fehlschlägt                                                                                                                                                                            //***************************************/                                                                                                                                                                            let batSocID = getState(ConfigData.statesPrefix + ".Settings.Tibber.tibberBatSocID").val                                                                                                                                                                            let tibberID = getState(ConfigData.statesPrefix + ".Settings.Tibber.tibberID").val                                                                                                                                                                            //***************************************/                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      var idOK = false                                                                                                                                                                            if (!batSocID || !tibberID) {                                                                                                                                                                                log("Versuche die IDs für Tibber und Batterielevel zu finden")                                                                                                                                                                                $("tibberlink.*.Homes.*.CurrentPrice.level").each(function (id, i) {                                                                                                                                                                                    tibberID = id                                                                                                                                                                                    createState(ConfigData.statesPrefix + ".Settings.Tibber.tibberID", tibberID, false)                                                                                                                                                                                    log("TibberID gefunden und gespeichert:" + id)                                                                                                                                                                                })                                                                                                                                                                                $(ConfigData.statesPrefix + ".app_device_property_*.data.InverterHeartbeat.batSoc").each(function (id, i) {                                                                                                                                                                                    if (getState(id).val > 0) {                                                                                                                                                                                        batSocID = id                                                                                                                                                                                        createState(ConfigData.statesPrefix + ".Settings.Tibber.tibberBatSocID", batSocID, false)                                                                                                                                                                                        log("batSocID gefunden und gespeichert:" + id)                                                                                                                                                                                    }                                                                                                                                                                                })                                                                                                                                                                                if (!batSocID || !tibberID) {                                                                                                                                                                                    log("Fehler bei der Ermittlung der IDs. Bitte händisch ins Script eintragen", 'error')                                                                                                                                                                                } else {                                                                                                                                                                                    idOK = true                                                                                                                                                                                }                                                                                                                                                                            } else {                                                                                                                                                                                idOK = true                                                                                                                                                                            }                                                                                                                                                                            if (idOK) {                                                                                                                                                                                checkTibber()                                                                                                                                                                                on({ id: tibberID, change: "ne" }, function (obj) {                                                                                                                                                                                    //log("Tibber Modul. tibberID Event:" + obj.state.val)                                                                                                                                                                                    checkTibber()                                                                                                                                                                                });                                                                                                                                                                                on({ id: batSocID, change: "ne" }, function (obj) {                                                                                                                                                                                    //log("Tibber Modul. batSocID Event:" + obj.state.val + "%")                                                                                                                                                                                    checkTibber()                                                                                                                                                                                });                                                                                                                                                                            }                                                                                                                                                                            function checkTibber() {                                                                                                                                                                                if (tibberID && batSocID) {                                                                                                                                                                                    const RegulateID = ConfigData.statesPrefix + "." + ConfigData.RegulationState                                                                                                                                                                                    let priceLevel = getState(tibberID).val;                                                                                                                                                                                    let batsoc = Number(getState(batSocID).val)                                                                                                                                                                                    let OldRegulate = toBoolean(getState(RegulateID).val)                                                                                                                                                                                    //log("Tibber Preislevel: " + priceLevel + " OldRegulate: " + OldRegulate + " batsoc: " + (batsoc))                                                                                                                                                                                    if ((tibberConfig.LevelToSwitch.includes(priceLevel))) {                                                                                                                                                                                        if (OldRegulate) {                                                                                                                                                                                            if (batsoc <= tibberConfig.BatMin) {                                                                                                                                                                                                setState(RegulateID, false);  // Regulierung aus                                                                                                                                                                                                setState(tibberConfig.SwitchID, true) //Schalter einschalten                                                                                                                                                                                                log("Script abgeschaltet AC-Ladung Ein, weil priceLevel:" + priceLevel + " batsoc:" + batsoc + "%")                                                                                                                                                                                            }                                                                                                                                                                                        } else {                                                                                                                                                                                            if (batsoc >= tibberConfig.BatMax) {                                                                                                                                                                                                setState(RegulateID, true);  // Regulierung an                                                                                                                                                                                                setState(tibberConfig.SwitchID, false) //Schalter ausschalten                                                                                                                                                                                                log(" Batterie bei BatMax. Script eingeschaltet AC-Ladung Aus. priceLevel:" + priceLevel + " batsoc:" + batsoc + "%")                                                                                                                                                                                            }                                                                                                                                                                                        }                                                                                                                                                                                    } else {                                                                                                                                                                                        if (!OldRegulate) {                                                                                                                                                                                            setState(RegulateID, true);  // Regulierung an                                                                                                                                                                                            setState(tibberConfig.SwitchID, false) //Schalter ausschalten                                                                                                                                                                                            log("Script eingeschaltet AC-Ladung Aus. priceLevel:" + priceLevel + " batsoc:" + batsoc + "%")                                                                                                                                                                                        }                                                                                                                                                                                    }                                                                                                                                                                                } else {                                                                                                                                                                                    //log("checkTibber skip. batsocID und/oder tibberID fehlen.")                                                                                                                                                                                }                                                                                                                                                                            }                                                                                                                                                                            //*************************************************************                                            
                    

                    Ich bekomme hier den Fehler angezeigt:

                    javascript.0 (52431) script.js.Ecoflow-Tibber: TypeError: Cannot read properties of null (reading 'email')
                    07:11:14.323	error	javascript.0 (52431) at script.js.Ecoflow-Tibber:25:65
                    07:11:14.324	error	javascript.0 (52431) at script.js.Ecoflow-Tibber:119:3
                    

                    Was kann ich da machen?

                    W Offline
                    W Offline
                    Waly_de
                    wrote on last edited by
                    #764

                    @karo2204 ist das eine rote oder eine Orange Meldung? Wenn orange müsste es dennoch laufen. Ich guck mir das morgen noch mal an.

                    K 1 Reply Last reply
                    0
                    • W Waly_de

                      @karo2204 ist das eine rote oder eine Orange Meldung? Wenn orange müsste es dennoch laufen. Ich guck mir das morgen noch mal an.

                      K Offline
                      K Offline
                      karo2204
                      wrote on last edited by karo2204
                      #765

                      @waly_de Die Meldung war gelb, aber jetzt bekomme ich solche Meldungen in rot. Habe Dein neustes Script drin von gestern:

                      at processTimers (node:internal/timers:512:7)

                      javascript.0
                      2023-11-05 06:00:17.177 error at listOnTimeout (node:internal/timers:569:17)

                      javascript.0
                      2023-11-05 06:00:17.177 error at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2743:34)

                      javascript.0
                      2023-11-05 06:00:17.177 error at Object.<anonymous> (script.js.Ecoflow-1162:919:9)

                      javascript.0
                      2023-11-05 06:00:17.176 error at CheckforReconnect (script.js.Ecoflow-1162:1299:9)

                      javascript.0
                      2023-11-05 06:00:17.176 error at script.js.Ecoflow-1162:921:13

                      javascript.0
                      2023-11-05 06:00:17.175 error at SetBasePower (script.js.Ecoflow-1162:1925:43)

                      javascript.0
                      2023-11-05 06:00:17.174 error Error in callback: TypeError: Cannot set properties of undefined (setting 'regulieren')

                      ioBroker
                      Tibber
                      Ecoflow Powerstream & Delta Max 2000

                      1 Reply Last reply
                      0
                      • W Offline
                        W Offline
                        Waly_de
                        wrote on last edited by Waly_de
                        #766

                        @karo2204 oha, da ist was anderes im Busch. Hast Du das Modul in den Quelltext des Hautscriptes eingefügt?
                        Bitte schau noch mal deine Settings etc durch, ob da nicht irgendwo eine Klammer fehlt. Vielleicht das Script noch einmal neu aufsetzen und die Settings anpassen.

                        K 1 Reply Last reply
                        0
                        • W Waly_de

                          @karo2204 oha, da ist was anderes im Busch. Hast Du das Modul in den Quelltext des Hautscriptes eingefügt?
                          Bitte schau noch mal deine Settings etc durch, ob da nicht irgendwo eine Klammer fehlt. Vielleicht das Script noch einmal neu aufsetzen und die Settings anpassen.

                          K Offline
                          K Offline
                          karo2204
                          wrote on last edited by karo2204
                          #767

                          @waly_de Es ist verrückt. Ich hatte ein paar Adapter für ein Dashboard installiert, diese deinstalliert, aber wohl nicht richtig. Jetzt per CLI deinstalliert und jetzt geht auch Dein Script wieder.....

                          Drück die Daumen, dass jetzt alles soweit geht! Um 10 Uhr sollte das Script wieder umspringen.

                          UPDATE: Hat funktioniert. Punkt 10 Uhr hat das Script die Steckdose ausgeschaltet und den Prio-Mode umgeschaltet. Heute Abend um 21 Uhr ist es wieder CHEAP, mal sehen was passiert 🙂

                          ioBroker
                          Tibber
                          Ecoflow Powerstream & Delta Max 2000

                          1 Reply Last reply
                          1
                          • K Offline
                            K Offline
                            karo2204
                            wrote on last edited by
                            #768

                            Hallo @Waly_de

                            Dein Script funktioniert wirklich super, nur ich hätte noch einen Verbesserungsvorschlag:

                            Leider schaltet der Prio-Modus nicht immer richtig um. Kann man ins 2. Script (Tibber/Ecoflow) noch etwas einbauen, damit stündlich versucht wird in den “richtigen” Prio-Modus zu schalten?

                            So entsteht im Moment manchmal ein Kreislauf, d.h. die DM wird über das Stromnetz geladen, gibt aber gleichzeitig wieder Strom ab. Erst wenn ich manuell den Prio-Modus umstelle, läuft alles so wie es soll.

                            ioBroker
                            Tibber
                            Ecoflow Powerstream & Delta Max 2000

                            W 1 Reply Last reply
                            0
                            • G Offline
                              G Offline
                              guhfy9966
                              wrote on last edited by
                              #769

                              Bei mir funktioniert auch alles super, danke für die tolle Arbeit.

                              Eine Frage:
                              Wie löst ihr das mit der Darstellung des Solar Ertrages am Tag. Die ecoflow App zeigt diese Werte ja eigentlich an, leider kann ich diese jedoch in den Objekten nicht finden.
                              Werden die irgendwo ausgelesen durch das Script?

                              Gibt es darüber hinaus eine Möglichkeit alle einzelnen Solarwerte auszuwerten? Also nicht nur die der Powerstreams, sondern auch die einer Delta2max als Beispiel.

                              Ich würde gerne jeglichen Solar Ertrag summieren und anzeigen.
                              Hat da jemand einen Tipp?

                              S P W 3 Replies Last reply
                              0
                              • Z Offline
                                Z Offline
                                Zedwarrior
                                wrote on last edited by
                                #770

                                Hallo,
                                erstmal danke an alle die sich hier Gedanken machen und Möglichkeiten schaffen den Mist von EcoFlow sinnvoll zu beschalten. Ich hab seit 2 Wochen versucht die Smartplug´s zum laufen zu bekommen aber die sind Müll. Selbst mit EcoFlow-Support haben die Dinger keine Einfluss auf meine Powerstream...
                                jetzt hab ichs mit ioBroker versucht
                                leider sagt der scrpt immer.

                                "avascript.0 (2028) script.js.EcoFlow: PowerStream [PowerStream] Batteriestand unter Limit:5% (0%). Limitiere Einspeiseleistung auf: 150W"

                                obwohl laut Akku halb voll ist.

                                Woran könnte das liegen?
                                Ich hab Seriennummer und DM2 im script eingetragen wie es sein soll.

                                S W 2 Replies Last reply
                                0
                                • G guhfy9966

                                  Bei mir funktioniert auch alles super, danke für die tolle Arbeit.

                                  Eine Frage:
                                  Wie löst ihr das mit der Darstellung des Solar Ertrages am Tag. Die ecoflow App zeigt diese Werte ja eigentlich an, leider kann ich diese jedoch in den Objekten nicht finden.
                                  Werden die irgendwo ausgelesen durch das Script?

                                  Gibt es darüber hinaus eine Möglichkeit alle einzelnen Solarwerte auszuwerten? Also nicht nur die der Powerstreams, sondern auch die einer Delta2max als Beispiel.

                                  Ich würde gerne jeglichen Solar Ertrag summieren und anzeigen.
                                  Hat da jemand einen Tipp?

                                  S Offline
                                  S Offline
                                  sirdir
                                  wrote on last edited by
                                  #771

                                  @guhfy9966 das mach ich nicht in iobroker sondern in Homeassistant. Da ist das ganz einfach. K.A. ob/wie das in iobroker ginge. Iobroker hab ich nur für dieses Script installiert, Homeassistant nutz ich schon seit Jahren…

                                  1 Reply Last reply
                                  0
                                  • Z Zedwarrior

                                    Hallo,
                                    erstmal danke an alle die sich hier Gedanken machen und Möglichkeiten schaffen den Mist von EcoFlow sinnvoll zu beschalten. Ich hab seit 2 Wochen versucht die Smartplug´s zum laufen zu bekommen aber die sind Müll. Selbst mit EcoFlow-Support haben die Dinger keine Einfluss auf meine Powerstream...
                                    jetzt hab ichs mit ioBroker versucht
                                    leider sagt der scrpt immer.

                                    "avascript.0 (2028) script.js.EcoFlow: PowerStream [PowerStream] Batteriestand unter Limit:5% (0%). Limitiere Einspeiseleistung auf: 150W"

                                    obwohl laut Akku halb voll ist.

                                    Woran könnte das liegen?
                                    Ich hab Seriennummer und DM2 im script eingetragen wie es sein soll.

                                    S Offline
                                    S Offline
                                    sirdir
                                    wrote on last edited by
                                    #772

                                    @zedwarrior wirklich DM2 und nicht D2M? schau dir mal die Objekte an die angelegt werden, ob die Sinn ergeben. Ansonsten kannst du das limit bei weniger als 5% ja auch auf 600 oder 800W stellen schon mal.

                                    1 Reply Last reply
                                    0
                                    • G guhfy9966

                                      Bei mir funktioniert auch alles super, danke für die tolle Arbeit.

                                      Eine Frage:
                                      Wie löst ihr das mit der Darstellung des Solar Ertrages am Tag. Die ecoflow App zeigt diese Werte ja eigentlich an, leider kann ich diese jedoch in den Objekten nicht finden.
                                      Werden die irgendwo ausgelesen durch das Script?

                                      Gibt es darüber hinaus eine Möglichkeit alle einzelnen Solarwerte auszuwerten? Also nicht nur die der Powerstreams, sondern auch die einer Delta2max als Beispiel.

                                      Ich würde gerne jeglichen Solar Ertrag summieren und anzeigen.
                                      Hat da jemand einen Tipp?

                                      P Offline
                                      P Offline
                                      Ponti92
                                      wrote on last edited by
                                      #773

                                      @guhfy9966 du kannst in iobroker den Adapter source analytics nehmen.
                                      Dieser addiert die Wh auf und dann kannst du dir den Zählerstand zb in die influxdb schreiben lassen.
                                      Anschließend kann man dann in Grafana die Werte pro Tag/woche/monat anzeigen lassen.

                                      Aber ist jetzt nicht so einfach, wie anscheinend bei homeassistant 😉

                                      Wobei ich die tatsächlichen Werte nicht aus dem EcoFlow Baum nehme, sondern meine energiesteckdose auslese.. das macht es ein Stück einfacher

                                      1 Reply Last reply
                                      0
                                      • G guhfy9966

                                        Bei mir funktioniert auch alles super, danke für die tolle Arbeit.

                                        Eine Frage:
                                        Wie löst ihr das mit der Darstellung des Solar Ertrages am Tag. Die ecoflow App zeigt diese Werte ja eigentlich an, leider kann ich diese jedoch in den Objekten nicht finden.
                                        Werden die irgendwo ausgelesen durch das Script?

                                        Gibt es darüber hinaus eine Möglichkeit alle einzelnen Solarwerte auszuwerten? Also nicht nur die der Powerstreams, sondern auch die einer Delta2max als Beispiel.

                                        Ich würde gerne jeglichen Solar Ertrag summieren und anzeigen.
                                        Hat da jemand einen Tipp?

                                        W Offline
                                        W Offline
                                        Waly_de
                                        wrote on last edited by Waly_de
                                        #774

                                        @guhfy9966 sagte in ecoflow-connector-Script zur dynamischen Leistungsanpassung:

                                        Bei mir funktioniert auch alles super, danke für die tolle Arbeit.

                                        Eine Frage:
                                        Wie löst ihr das mit der Darstellung des Solar Ertrages am Tag. Die ecoflow App zeigt diese Werte ja eigentlich an, leider kann ich diese jedoch in den Objekten nicht finden.
                                        Werden die irgendwo ausgelesen durch das Script?

                                        Gibt es darüber hinaus eine Möglichkeit alle einzelnen Solarwerte auszuwerten? Also nicht nur die der Powerstreams, sondern auch die einer Delta2max als Beispiel.

                                        Ich würde gerne jeglichen Solar Ertrag summieren und anzeigen.
                                        Hat da jemand einen Tipp?

                                        Also ich löse das mit Influxdb 2.0 und grafana. Datenquelle ist der Wert
                                        0_userdata.0.ecoflow.totalPV den ich Protokollieren lasse.
                                        in Grafana sieht das dann so aus:

                                        Bildschirmfoto 2023-11-15 um 10.40.52.jpg

                                        hier die Abfrage dazu:

                                        from(bucket: "iobroker")
                                          |> range(start: -30d, stop: now())
                                          |> filter(fn: (r) => r["_measurement"] == "totalPV" and r["_field"] == "value")
                                          |> aggregateWindow(every: 60s, fn: mean, createEmpty: false)
                                          |> map(fn: (r) => ({
                                              _time: r._time,
                                              _value: r._value / 60000.0  // Umrechnung von Watt in Kilowatt
                                          }))
                                          |> aggregateWindow(every: 1d, fn: sum, createEmpty: false, location: {zone: "Europe/Berlin", offset: 0h})  // tägliche Summierung in der angegebenen Zeitzone
                                          |> map(fn: (r) => ({
                                              _time: r._time,
                                             Ertrag: r._value  // Dies ist nun die Summe der Energieverbräuche in kWh pro Tag
                                          }))
                                          |> yield(name: "kWh_pro_Tag")
                                        
                                        
                                        
                                        

                                        Kommt bei mir ganz gut hin 🙂

                                        im Script kannst du ja alle Solarwerte mit den Parametern: AdditionalPower erfassen und in totalPV aufnehmen lassen. Musst nur den Pfad zu dem Zustand in IoBroker angeben.

                                        G 1 Reply Last reply
                                        0
                                        • Z Zedwarrior

                                          Hallo,
                                          erstmal danke an alle die sich hier Gedanken machen und Möglichkeiten schaffen den Mist von EcoFlow sinnvoll zu beschalten. Ich hab seit 2 Wochen versucht die Smartplug´s zum laufen zu bekommen aber die sind Müll. Selbst mit EcoFlow-Support haben die Dinger keine Einfluss auf meine Powerstream...
                                          jetzt hab ichs mit ioBroker versucht
                                          leider sagt der scrpt immer.

                                          "avascript.0 (2028) script.js.EcoFlow: PowerStream [PowerStream] Batteriestand unter Limit:5% (0%). Limitiere Einspeiseleistung auf: 150W"

                                          obwohl laut Akku halb voll ist.

                                          Woran könnte das liegen?
                                          Ich hab Seriennummer und DM2 im script eingetragen wie es sein soll.

                                          W Offline
                                          W Offline
                                          Waly_de
                                          wrote on last edited by
                                          #775

                                          @zedwarrior Das Script ließt den Wert aus dem PowerStream aus, auch wenn du deinen Delta garnicht anlegst. Wird also 0% Angezeigt, stimmt etwas mit der Verbindung PS-Delta nicht.
                                          Guck mal ob du auch 100% den PS mit Eingang 1 der Delta verbunden hast.

                                          Ausserdem musst du vielleicht etwas Geduld haben, denn die Werte werden nicht so häufig (vielleicht nur bei Änderung) aktualisiert.

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          167

                                          Online

                                          32.4k

                                          Users

                                          81.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe