NEWS
Geräte zu Stundenpreisen (EPEX) oder PV-Überschuss betreiben
-
@einstein-0 sagte in Geräte zu Stundenpreisen (EPEX) oder PV-Überschuss betreiben:
Hast du eine Idee wie ich nur den Stundenwert in das Objekte schreiben kann?
Ich bin leider nicht ganz so fit im Scripting.
Es gibt im JavaScript aber der Befehl.charAt(1)
Damit nimmt er den zweiten "Wert" in Deiner Zeichenfolge (Zeichenfolge fängt immer mit 0 an, also 0,1,2,3,4...
Du hast ja´4´,0.2531
da stehen somit wäre das erste Hochzeichen charAt(0), Dein Stundenwert eben charAt(1) usw.
Vor dem Punkt steht Dein Objekt.
Also irgendwas mit´GünstigsteStunde1´.charAt(1)
Damit hast dann nur den Stundenwert (Ich weiß jetzt nur nicht, ob der Datenpunkt richtig angegeben wurde).
Irgendwie so, schon mal in die Richtung geschubst.
-
@tugsi
@Einstein-0
Hallo zusammen und sorry, dass ich mich zwischenzeitlich nicht habe melden können. Vielleicht kann meine Info Euch ja dennoch unterstützen...Dem gesamten Ansatz möchte ich voranstellen, dass das Laden einer PV-Batterie mit Netzstrom NICHT ZULÄSSIG IST, wenn die Batterie Teil einer PV-Anlage mit EEG-Förderung ist.
... nur zur Sicherheit... Ich gehe davon aus, dass dies in diesem Fall nicht zutrifft.Die Gedanke und Ansätze von @tugsi teile ich. An der Stelle breche ich mir auch gerade die Finger - aua . Mal schauen was uns dazu noch einfällt. Im Moment ist dieser Teil zurückgestellt.
Für das Laden meines BEVs hatte ich die Notwendigkeit die günstigen Stunden über einen Zeitraum von bis zu 48h aus den Tibberdaten zu ermitteln. Da ich nicht mit den Werten in den einzelnen Datenpunktordnern arbeite, habe ich dies über eine Liste realisiert. Alle Werte (Preis, Stunde, Reihenfolge) werden in eine Liste geschrieben. Diese Liste wird dann sortiert, umgestellt, gekürzt bis es passt.
2023-12-07_EPEX_TIBBER_günstige Stunden zum Laden.json
Sofern es Euch hilft und Ihr die Zeit investieren möchtet... Die relevanten Abschnitte finden sich in "FKT_4_..." und "FKT_5_...". Leider schaffe ich es nicht, das Skript umfangreicher zu erläutern... Vielleicht findet sich für Euch aber noch ein Ansatz.
In einem anderen Thread beschrieb ich mal den Vorgänger des eingefügten Scripts.
https://forum.iobroker.net/topic/68266/bev-mit-epex-börsen-strom-laden?_=1701958474745
Die Beschreibung passt also nicht mehr komplett, aber die Ausführungen zu den beiden Funktionen passen noch.Beste Grüße, Thomas
-
@thomkast sagte in Geräte zu Stundenpreisen (EPEX) oder PV-Überschuss betreiben:
Dem gesamten Ansatz möchte ich voranstellen, dass das Laden einer PV-Batterie mit Netzstrom NICHT ZULÄSSIG IST, wenn die Batterie Teil einer PV-Anlage mit EEG-Förderung ist.
Der Passus ist mir bekannt und im Grunde gibt es dazu ausreichend kontroverse Diskussionen und Argumente im Netz
Es gibt sogar Aussagen die sagen, es wäre doch durchaus möglich.
Was allerdings zwingend nicht erlaubt ist, dass einspeisen ins Netz durch die Batterie.Ich möchte das hier jetzt auch nicht aufdröseln, soll jeder selber sich ein Bild im Netz machen.
Ich lade mein gefördertes Elektroauto mit Netzstrom, dies ist erlaubt.
Mein um einiges kleinerer Speicher, für Eigenbedarf (ich rede nicht von Zurückspeisen ins Netz), darf ich nicht benutzen, weil ich eine 20 Jahresförderung für eingespeisten Strom bekomme ...
Und dies obwohl ich zweckdienlich einen Überstrom im deutschen Netz nutze und somit für Netzstabilität sorge ...
Ich sage nur, finde den Fehler.Aber korrekt wäre es anders . Gut, dass Du nochmal darauf hingewiesen hast (das meine ich ehrlich und nicht ironisch!).
Das Laden meines Autos mache ich semiautomatisch, ich habe eine selbstgebaute openWB, noch mit der 1.9er Software. Die holt sich von Tibber die Daten und zeigt mir den Strompreis an.
Da kann ich dann einstellen, bei welchem Strompreis ich laden möchte, wenn der unterschritten wird.
Ja, dies passiert händisch, weil es ja auch davon abhängt, wie brauche ich das Auto und wie ist der Preis.Beispiel, ich weiß, morgen fahre ich mindestens 150km, brauche also dementsprechende Ladung, dann gibt es für mich folgende Szenarien:
- Akku ist ausreichend voll, Strompreis mir persönlich zu hoch = nix tun
- Akku ausreichend voll, Strompreis aber günstig = lade in der Zeit den Akku nach
- Akku zu leer, Strompreis hoch = günstigste Zeit wählen und nur das "Minimum" nachladen plus Reserve
- Akku zu leer, Strompreis günstig = wie Punkt 2
Dein Script schaue ich mir mal in Ruhe an, wenn ich mehr Muse habe, wie gesagt, ich bin mir da unsicher, ob ich das automatisieren sollte.
Gruß Thomas
-
@thomkast sagte in Geräte zu Stundenpreisen (EPEX) oder PV-Überschuss betreiben:
Sofern es Euch hilft und Ihr die Zeit investieren möchtet... Die relevanten Abschnitte finden sich in "FKT_4_..." und "FKT_5_...". Leider schaffe ich es nicht, das Skript umfangreicher zu erläutern... Vielleicht findet sich für Euch aber noch ein Ansatz.
Habe doch mal kurz Dein Script importiert (wobei Du hier im Thread nur Fkt1 hast, daher aus Deinem Urpsrungsthread genommen)
Dort ist ja schon sowas, was @Einstein-0 sucht:
Aus Deiner Liste nimmst Du doch die entsprechende Stelle dann raus.
Hast Du mal kurzen Ausschnitt aus der Liste, dann kann @Einstein-0 den Aufbau genau sehen.
Ich denke das hilft ihm weiter. -
@tugsi
Das sieht am aktuellen Beispiel dann so aus: -
Ist es möglich deine tolle Arbeit auch für den österreichischen Anbieter SmartEnergy zu nutzen ?
Hier ist der Link zu deren API: https://www.smartenergy.at/api-schnittstellen
Lässt sich das mit deinen Scripten machen und falls ja was müsste ich da genau tun ?
Beste Grüße
-
@qlink der Börsenstrompreis, sollte überall gleich sein.... das was der Anbieter noch aufschlägt sollte ja auch immer "gleich" sein....
Somit íst das hier immer zu gebrauchen...
edit
ah mist... es muss ja einTiber token benutzt werden... dann ist das natürlich nicht mal eben für was anderes zu benutzen.....Bringt dich der Awattar-Adapter nicht auch zum Ziel?
-
Leider nein, nur einfach austauschen der API URL im awattar Adapter funktioniert nicht.
Hab dazu auch schon einen Github Request aufgemacht, aber bei dem awattar Adapter hat sich lt. Github scheinbar seit 3 Jahren nichts mehr getan, daher hab ich da auch eher wenig Hoffnung auf Lösung meiner Anfrage. -
@qlink Moin aus dem verregneten Norddeutschland nach Österreich und alles Gute im neuen Jahr .
Ich schaue mir die API mal an und melde mich dann. Wenn es nicht zu umfangreich wird, helfe ich gerne. -
-
@qlink Hi, wenn Du mal schauen möchtest...
Dieses Blockly-Script holt die Daten von APIS ab (1.Teil) und mit dem 2.Teil hast Du Zugriff auf die Stundenpreise.
- Teil speichert die Daten im Datenpunkt unter 0_userdata.0.APIS_AT.Preise_heute
APIS beschreibt ja, dass die Daten um 1700 für den Folgetag "mit enthalten" sind. Wie das dann aussieht müssen wir noch schauen.
Lässt Du das Blockly-Script vor 1700 laufen, erhälst Du schon mal die Daten des aktuellen Tages.Den 1.Teil würde ich nur 1mal aufrufen und dann mit dem Datenpunkt (2. Teil) arbeiten, damit die API-Quelle nicht unnötig belastet wird.
... vielleicht beschreibst Du mal, was Du genau machen möchtest...
... warum APIS die Preise 1/4stündlich anbietet erschließt sich mir nicht. Wie ist denn die Preisgestaltung des Anbieters? -
@thomkast Hi,
Habe dein erstelltes Skript (SmartEnergy) mal importiert- vielen Dank dafür. Skript funktioniert nach dem Anlegen des DP. Ich würde gerne meinen Warmwasserspeicher mit dem günstigsten Stundenpreis aufheizen. Zur Zeit geht das zwar mit meinem Skript aber dieses vergleicht nicht die kommenden Preise sonder) startet die WP beim unterschreiten der eingestellten Grenze. Hast du eine Idee wie ich das lösen könnte?
-
Vielen Dank für deinen Support !
Ich habe unter Objekte einen DP "0_userdata.0.APIS_AT.Preise_heute" vom Typ "json" erstellt und danach dein Script gestartet.
Daraufhin erhalte ich folgenden Inhalt in dem DP:
- {"tariff":"EPEXSPOTAT","unit":"ct/kWh","interval":15,"data":[{"date":"2024-01-04T00:00:00+01:00","value":6.876},{"date":"2024-01-04T00:15:00+01:00","value":6.876},{"date":"2024-01-04T00:30:00+01:00","value":6.876},{"date":"2024-01-04T00:45:00+01:00","value":6.876},{"date":"2024-01-04T01:00:00+01:00","value":6.055},{"date":"2024-01-04T01:15:00+01:00","value":6.055},{"date":"2024-01-04T01:30:00+01:00","value":6.055},{"date":"2024-01-04T01:45:00+01:00","value":6.055},{"date":"2024-01-04T02:00:00+01:00","value":4.800},{"date":"2024-01-04T02:15:00+01:00","value":4.800},{"date":"2024-01-04T02:30:00+01:00","value":4.800},{"date":"2024-01-04T02:45:00+01:00","value":4.800},{"date":"2024-01-04T03:00:00+01:00","value":3.058},{"date":"2024-01-04T03:15:00+01:00","value":3.058},{"date":"2024-01-04T03:30:00+01:00","value":3.058},{"date":"2024-01-04T03:45:00+01:00","value":3.058},{"date":"2024-01-04T04:00:00+01:00","value":4.200},{"date":"2024-01-04T04:15:00+01:00","value":4.200},{"date":"2024-01-04T04:30:00+01:00","value":4.200},{"date":"2024-01-04T04:45:00+01:00","value":4.200},{"date":"2024-01-04T05:00:00+01:00","value":6.928},{"date":"2024-01-04T05:15:00+01:00","value":6.928},{"date":"2024-01-04T05:30:00+01:00","value":6.928},{"date":"2024-01-04T05:45:00+01:00","value":6.928},{"date":"2024-01-04T06:00:00+01:00","value":8.718},{"date":"2024-01-04T06:15:00+01:00","value":8.718},{"date":"2024-01-04T06:30:00+01:00","value":8.718},{"date":"2024-01-04T06:45:00+01:00","value":8.718},{"date":"2024-01-04T07:00:00+01:00","value":10.202},{"date":"2024-01-04T07:15:00+01:00","value":10.202},{"date":"2024-01-04T07:30:00+01:00","value":10.202},{"date":"2024-01-04T07:45:00+01:00","value":10.202},{"date":"2024-01-04T08:00:00+01:00","value":10.976},{"date":"2024-01-04T08:15:00+01:00","value":10.976},{"date":"2024-01-04T08:30:00+01:00","value":10.976},{"date":"2024-01-04T08:45:00+01:00","value":10.976},{"date":"2024-01-04T09:00:00+01:00","value":11.304},{"date":"2024-01-04T09:15:00+01:00","value":11.304},{"date":"2024-01-04T09:30:00+01:00","value":11.304},{"date":"2024-01-04T09:45:00+01:00","value":11.304},{"date":"2024-01-04T10:00:00+01:00","value":10.985},{"date":"2024-01-04T10:15:00+01:00","value":10.985},{"date":"2024-01-04T10:30:00+01:00","value":10.985},{"date":"2024-01-04T10:45:00+01:00","value":10.985},{"date":"2024-01-04T11:00:00+01:00","value":10.794},{"date":"2024-01-04T11:15:00+01:00","value":10.794},{"date":"2024-01-04T11:30:00+01:00","value":10.794},{"date":"2024-01-04T11:45:00+01:00","value":10.794},{"date":"2024-01-04T12:00:00+01:00","value":10.355},{"date":"2024-01-04T12:15:00+01:00","value":10.355},{"date":"2024-01-04T12:30:00+01:00","value":10.355},{"date":"2024-01-04T12:45:00+01:00","value":10.355},{"date":"2024-01-04T13:00:00+01:00","value":10.315},{"date":"2024-01-04T13:15:00+01:00","value":10.315},{"date":"2024-01-04T13:30:00+01:00","value":10.315},{"date":"2024-01-04T13:45:00+01:00","value":10.315},{"date":"2024-01-04T14:00:00+01:00","value":11.053},{"date":"2024-01-04T14:15:00+01:00","value":11.053},{"date":"2024-01-04T14:30:00+01:00","value":11.053},{"date":"2024-01-04T14:45:00+01:00","value":11.053},{"date":"2024-01-04T15:00:00+01:00","value":11.834},{"date":"2024-01-04T15:15:00+01:00","value":11.834},{"date":"2024-01-04T15:30:00+01:00","value":11.834},{"date":"2024-01-04T15:45:00+01:00","value":11.834},{"date":"2024-01-04T16:00:00+01:00","value":12.499},{"date":"2024-01-04T16:15:00+01:00","value":12.499},{"date":"2024-01-04T16:30:00+01:00","value":12.499},{"date":"2024-01-04T16:45:00+01:00","value":12.499},{"date":"2024-01-04T17:00:00+01:00","value":12.592},{"date":"2024-01-04T17:15:00+01:00","value":12.592},{"date":"2024-01-04T17:30:00+01:00","value":12.592},{"date":"2024-01-04T17:45:00+01:00","value":12.592},{"date":"2024-01-04T18:00:00+01:00","value":12.348},{"date":"2024-01-04T18:15:00+01:00","value":12.348},{"date":"2024-01-04T18:30:00+01:00","value":12.348},{"date":"2024-01-04T18:45:00+01:00","value":12.348},{"date":"2024-01-04T19:00:00+01:00","value":12.593},{"date":"2024-01-04T19:15:00+01:00","value":12.593},{"date":"2024-01-04T19:30:00+01:00","value":12.593},{"date":"2024-01-04T19:45:00+01:00","value":12.593},{"date":"2024-01-04T20:00:00+01:00","value":12.012},{"date":"2024-01-04T20:15:00+01:00","value":12.012},{"date":"2024-01-04T20:30:00+01:00","value":12.012},{"date":"2024-01-04T20:45:00+01:00","value":12.012},{"date":"2024-01-04T21:00:00+01:00","value":11.186},{"date":"2024-01-04T21:15:00+01:00","value":11.186},{"date":"2024-01-04T21:30:00+01:00","value":11.186},{"date":"2024-01-04T21:45:00+01:00","value":11.186},{"date":"2024-01-04T22:00:00+01:00","value":10.892},{"date":"2024-01-04T22:15:00+01:00","value":10.892},{"date":"2024-01-04T22:30:00+01:00","value":10.892},{"date":"2024-01-04T22:45:00+01:00","value":10.892},{"date":"2024-01-04T23:00:00+01:00","value":10.634},{"date":"2024-01-04T23:15:00+01:00","value":10.634},{"date":"2024-01-04T23:30:00+01:00","value":10.634},{"date":"2024-01-04T23:45:00+01:00","value":10.634}]}
War das soweit korrekt ?
Wenn ja, bin ich mir jetzt nicht ganz sicher wie die nächsten Schritte ausschauen sollen ...Beste Grüße
-
@qlink Wenn Du meine Fragen beantworten und vor allem auf "... was Du genau machen möchtest..." eingehen würdest könnte ich vielleicht mitdenken...
-
@peter666666 dazu müsste ich Deinen Gedanken erst komplett verstanden haben...
Ich vermute mal:
- Du möchtest Deinen WW-Speicher zu den günstigsten Stundenpreisen aufheizen
- teils auch "überheizen", wenn "in absehbarer Zeit" keine günstige Stunde mehr ansteht
Sollte das stimmen, stellt sich die Frage, welche Wärmemenge über welche Zeit aus dem WW-Speicher entnommen werden soll. Und wie viel Energie zum Aufheizen wiederum benötigt wird.
Oder anders ausgedrückt... Wie lange es dauert bis die MIN-Temperatur (durch Wärmeentnahme) erreicht wird. Und wie lange es dauert bis die MAX-Temperatur wieder erreicht wird.
Und eine weitere Perspektive... Wie lange der Speicher auf MIN-Temperatur verbleiben darf, um auf eine günstige Stunde zu warten.
Daraus wiederum die Frage, ob bei zu langer Wartezeit - unabhängig des Stundenpreises - auf eine höhere Temperatur, aber kleiner MAX aufgeheizt werden soll.Dies sind konzeptuale Fragen, zu denen Du bitte Deine Absicht und Abhängigkeiten aufschreiben müsstest...
Ich bin gespannt
-
@thomkast Hallo Thomas,
meine WP (10 Jahre alt und hat keine Möglichkeit mit Netzwerkkabel oder ähnlichem diese zu steuern) ist zur Zeit so eingestellt das diese ab 40°C WW zu heizen beginnt auf 48°C unabhängig vom Strompreis. Im Sommer habe ich mir mit 2 Shelly1 die Möglichkeit geschaffen die Funktion "Extra Brauchwasser" anzusteuern wodurch die WP beginnt die WW Temp. auf 60°C zu erhitzen und mit dem 2 Shelly wir die Funktion wieder deaktiviert wenn genug PV Überschuss vorhanden ist was auch funktioniert.
Jetzt im Winter ist nicht viel mit PV Überschuss und möchte in einem neuen Skript die günstigsten Strompreise je Tag nutzen diese Funktion Extrabrauchwasser zu starten wenn die WWT unter z.b. 54°C ist. Überheizen oder so kann meine WP nicht. -
@peter666666 ok und interessant. Meine WP könnte ich von extern dazu bringen, auf unterscheidliche Temperaturen zu erhitzen. Ist also ähnlich... Allerdings habe ich dazu noch keine Logik realisiert.
Für mich bleibt die Frage unter welchen Bedingungen die WP bis zu welcher Temperatur aufheizen soll? Was wären denn Deiner Meinung nach die Möglichen Parameter oder eine Beschreibung für eine "planbare Aufheizung"... s.o.
-
@thomkast Bedingung wäre für mich wie in meinem bestehenden Skript (steht weiter oben), das das "Aufheizen mit billigem Strom" aktiv sein muss (DP wird manuell am Tablet unter VIS geschalten), die WWT unter einen Wert sinkt (z.Z. 54°C). Dann sollte das Skript die billigste Stunde suchen (wobei ich noch nicht ganz sicher bin in welchen Zeitraum gesucht werden soll vielleicht 6h) wo die WP dann startet. Bei dem Start (Shelly1 schaltet den Kontakt Anforderung "Extra Brauchwasser" durch eine billige Energiestunde bis auf ca. 58°C aufheizen. Wenn diese Temp. erreicht ist (wird durch einen Shelly1+ gemessen) schaltet ein anderer Shelly die WP aus indem ich für 5 Sek. den Kontakt "Tarif Steuerung" oder so ähnlich schalte wodurch der Verdichter ausgeschaltet und die Anforderung "Extra Brauchwasser" zurückgesetzt wird (ohne diesen zweiten Shelly würde die Anforderung "Extra Brauchwasser" nämlich 3h aktiv bleiben und diese lässt sich nicht anders zurück setzten.
Die Energiepreise bekomme ich über den Adapter Awattar in DP`s auch in aufsteigender Reihenfolge (billigste Stunde zuerst) und auch über dein Skript von meinem Energieanbieter "Smart Energy" wobei hier die Liste nicht aufsteigend sortiert ist.
-
@Peter666666 @Qlink Nur als kurzes Update. Ich bin noch an einem Lösungsansatz dran, hänge aber gerade etwas fest. Melde mich aber auf alle Fälle wieder/noch.
-
@Peter666666 @Qlink
Jetzt hat es doch etwas länger gedauert einen Lösungsansatz zu finden. Vielleicht hilft Euch folgende Umsetzung...Skript: 2024-01-07_APIS_EPEX_sortieren_und_Laden-Aufheizen.json
Dazu ist wieder der Datenpunkt zur Aufnahme der APIS EPEX Preise nötig ;-).
Idee und Ablauf sind wie folgt:
-
- Die APEX Daten werden (bitte nur 1malig am Tag) geladen.
Erfolgt dies nach ??:?? Uhr, stehen auch gleich die Daten des Folgetages bereit.
- Die APEX Daten werden (bitte nur 1malig am Tag) geladen.
-
- Die Daten werden in einem Array aufbereitet und nach Preis aufsteigend sortiert.
Somit stehen die Stunden mit den günstigsten EPEX-Preisen am Anfang des Arrays.
- Die Daten werden in einem Array aufbereitet und nach Preis aufsteigend sortiert.
-
- Mit dem Wert wird festgelegt, für wieviele Stunden eine Ladung/Aufheizung vorgenommen werden soll. Dies sind "NICHT" die "NÄCHSTEN" z.B. 5h, sondern erstmal nur 5 Stunden.
-
- Dann werden die günstigsten 5h wieder in die ursprüngliche Reihenfolge gebracht, da die günstigsten Stunden ja nicht unbedingt alle hintereinander liegen müssen.
-
- Dann wird ein Zeitplan gestartet, der zu jedem Stundenbeginn prüft, ob die aktuelle Stunde eine der günstigen 5 Stunden ist.
-
- Abhängig, ob dies zutrifft, wird die Ladung/Aufheizung gestartet oder beendet.
Dazu werden dann noch Nachrichten abgesetzt, die den Verlauf aufzeigen.
*7. Sind die 5 (im Beispiel) günstigsten Lade-/Aufheizstunden durchlaufen worden, wird eine finale Nachricht abgesetzt und der Zeitplan beendet.
- Abhängig, ob dies zutrifft, wird die Ladung/Aufheizung gestartet oder beendet.
Die gesamte Routine muss also wiederkehrend gestartet werden und kalkuliert immer wieder neu.
Hoffe es ist was für Euch dabei und freue mich auf Eure Rückmeldung. Gruß, Thomas
-