NEWS
Daten aus Fronius Solarweb auslesen
-
@strobelix erst einmal vielen Dank für die Erklärung. Ein paar DP hab ich ja schon rausgefunden, einige waren mir nicht klar. Mit dieser Liste kann ich mir die passenden DP raussuchen und für Influx und Grafana vormerken.
-
Vorab, Danke für das Super Script das einiges an Arbeit abnimmt! Ich verstehe den Forecast (Heute/Morgen) nur noch nicht richtig. Gelten die Werte immer von 0:00 Uhr - 23:59 Uhr oder wie wird das berechnet? Und „Forecast Tomorrow“ dann auch von 0:00 Uhr des kommenden Tages bis 23:59 Uhr oder gelten die 48h von der Stunde an wo die Daten abgerufen werden?
Weiß man eigentlich schon warum die Forecast-Daten immer mal wieder abweichen zu den Daten auf der Solar.web Homepage? Aktuell zeigt mir der Datenpunkt z.B. 3,90 kW an und vorher war es um die 38 kW aber auf der Homepage steht was von 49 kW, was auch deutlich besser passt.
-
Gute MOrgen zusammen,
kurze Frage an alle Script Nutzer die AUCH einen Discovergy Zähler als Hauptzähler verwenden.Also der der Discovergy Zähler ist mein geeichter Zähler, nach dessen Werten sowohl mein Strom Bezug, als auch meine Einspeisung berechnet / vergütet wird.
Seit der tabellarischen Auflistung der Daten vom Fronius Smartmeter, kann ich die beiden Punkte Bezug und Einspeisung sehr schnell 1:1 vergleichen.
Hierbei ist mir aufgefallen, das es zwischen Fronius und Discovergy immer wieder Abweichungen gibt, welche mal in die eine, oder die andere Richtung gehen. Dieses hängt nach meinen Beobachtungen sehr davon ab, ob es ein sonniger oder trüber Tag war und ob an diesen Tagen viele Großverbraucher mit ihren Peak Belastungen in Betrieb waren.
Da bei der steuerlichen Betrachtung der PV Anlage ja auch der Eigenverbrauch in die Rechnung mit einfließt, scheint es für mich im Moment so, das die Berechungsgrundlage aufgrund der Fronius Smartmeter Daten für mich steuerlich ungünstiger ausfallen, weil hier ein höherer Eigenverbrauch berechnet wird.
Ich würde da an dieser Stelle eher dem geeichten Discovergy Smartmeter "trauen". Allerdings muss ich ja für die Berechnung des Eigenverbrauch die Erzeugungswerte vom Fronius Smartmeter her nehmen, da ich keinen separaten Erzeugungszähler außer dem Fronius Smartmeter habe.
Hat hier noch jemand ähnliche Beobachtungen gemacht?
Beispiel:
11.2.2022 (normaler grauer Wolken Tag) - Erzeugung: 4,28 kwh (lt. Fronius Smartmeter)
Bezug lt. Fronius: 5,62 kwh - lt. Discovergy: 6,02 kwh
Einspeisung lt. Fronius: 0,16 kwh - lt. Discovergy: 0,144 kwh
Differenz Erzeugung -> Eigenverbrauch lt. Fronius: 4,12 kwh
Differenz Erzeugung-> Eigenverbrauch Discovergy: 4,136 kwh <- höher als Fronius07.02.2022 (viel Sonne) Erzeugung: 10,72 kwh (lt. Fronius Smartmeter)
Bezug lt. Fronius: 3,26 kwh - lt. Discovergy: 3,19 kwh
Einspeisung lt. Fronius: 0,87 kwh - lt. Discovergy: 0,952 kwh
Differenz Erzeugung -> Eigenverbrauch lt. Fronius: 9,85 kwh
Differenz Erzeugung -> Eigenverbrauch lt. Discovergy: 9,768 kwh <- niedriger als Fronius -
@triple-m said in Daten aus Fronius Solarweb auslesen:
Gelten die Werte immer von 0:00 Uhr - 23:59 Uhr oder wie wird das berechnet? Und „Forecast Tomorrow“ dann auch von 0:00 Uhr des kommenden Tages bis 23:59 Uhr oder gelten die 48h von der Stunde an wo die Daten abgerufen werden?
Die Werte gelten immer von Heute 0-24 und Morgen 0-24, sonst wäre der Wert ja ab Mittags +24h schon für Morgen.
Wenn tagsüber Werte für Heute abgefragt werden, kommen nur noch die Forecastwerte von dem Abfragemoment bis 24:00. Zu diesem Wert wird dann die bisherige Tagesproduktion hinzugerechnet. Das weicht leider immer wieder bisschen von der Solarweb-Ansicht ab, warum weiss ich nicht genau, manchmal stimmt es auch überein (vermutlich ein timezone-Problem zwischen Froniusserver und Anlagenstandort..siehe unten).
Am Morgen und nach Sonnenuntergang ist es dann meist identisch zu Solarweb, tagsüber schleichen sich da kleine Fehler ein.
Wenn die Werte manchmal sehr niedrig sind (hab das Problem auch), dann addiert das Script die bisherige Tagesproduktion NICHT zu dem verbleibenden Tagesforecast. Dem Fehler bin schon auf der Spur, aber noch nicht ganz gelöst.Erklärung Timezone:
Grundsätzlich kommen die Forecastwerte in 15min Werten für den heutigen Tag, das sind bei 24h also 96 Einzelwerte die addiert werden. Ich vermute das da zB um 14:00 noch Werte von 13:00 mit kommen (oder die ab 15:00 und dann eine Stunde fehlt), weil man bei Abfrage die Timezone angeben kann und da vielleicht was nicht passt.
Hab mit der Timezone schon mehrere Versuche gemacht, aber das macht keinen Unterschied das es mal Abweicht und mal nicht. -
@strobelix
Danke dir. Grundsätzlich hört sich das gut an nur hatte ich vorhin, nach Sonnenuntergang, auch das 0,00 kW angezeigt werden. Vermutlich auch durch das Problem was du beschreibst.
Wäre es evtl. eine Idee einen weiteren Datenpunkt zu erstellen wo dann die restliche Produktion des Tages addiert wird? Dann könnte man auf einen Blick sehen was man jetzt noch erwarten kann und bestimmt auch für das ein oder andere nutzen. -
@triple-m
Ok also einem Datenpunkt mit Forecast Today remaining .. oder so
Das wäre kein Problem -
@strobelix
Ja genau. Das wäre super danke. -
@triple-m Im ersten Beitrag ist nun das angepasst Blockly.
Ich denke das ich den Fehler mit der Addition zwar jetzt im Griff habe, ich habe trotzdem folgendes angepasst.Die verbleibende Vorhersage für den aktuellen Tag wird nun auch als eigener Datenpunkte dargestellt.
Es gibt einen Button um ausserhalb des Scriptzeitplans die Forecast-Werte manuell abzurufen. -
@strobelix
Super danke dir. Werde ich morgen gleich mal testen. -
@strobelix
Das geänderte Blockly passt und funktioniert nur ich bekomme, auch schon mit der vorherigen Version, etliche Warnmeldungen im Protokoll, wie z.B.:2022-02-14 00:00:00.008 - warn: javascript.0 (4697) getState "0_userdata.0.Solarweb.Token" not found (3) 2022-02-14 00:00:00.011 - warn: javascript.0 (4697) at Monatsdaten (script.js.common.Fronius_SolarWeb:267:20) 2022-02-14 00:00:00.011 - warn: javascript.0 (4697) at Object. (script.js.common.Fronius_SolarWeb:445:11) 2022-02-14 00:00:00.011 - warn: javascript.0 (4697) at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1313:34) 2022-02-14 00:00:00.011 - warn: javascript.0 (4697) at Job.invoke (/opt/iobroker/node_modules/node-schedule/lib/Job.js:168:15) 2022-02-14 00:00:00.011 - warn: javascript.0 (4697) at /opt/iobroker/node_modules/node-schedule/lib/Invocation.js:268:28 2022-02-14 00:00:00.011 - warn: javascript.0 (4697) at Timeout._onTimeout (/opt/iobroker/node_modules/node-schedule/lib/Invocation.js:228:7) 2022-02-14 00:00:00.011 - warn: javascript.0 (4697) at listOnTimeout (node:internal/timers:559:17) 2022-02-14 00:00:00.011 - warn: javascript.0 (4697) at processTimers (node:internal/timers:502:7) 2022-02-14 00:00:00.048 - warn: javascript.0 (4697) You are assigning a number to the state "0_userdata.0.Solarweb.Current.02_Weekdays.Aktuelle_Wochentagwerte_abrufen" which expects a boolean. Please fix your code to use a boolean or change the state type to number. This warning might become an error in future versions.
Das ist nur ein Auszug, ich bekomme wie gesagt etliche davon und immer wieder.
Mod-Edit: Code in </> Code-Tag gepackt!
-
Könntest du noch bitte die Fehlermeldungen ausbauen bzw nicht als error klassifizieren, wenn man kein premium hat?
javascript.0 2022-02-14 09:00:04.208 error script.js.Fronius: Solarweb Forecast Forecast Tomorrow konnte nicht abgefragt werden javascript.0 2022-02-14 09:00:02.204 error script.js.Fronius: Solarweb Forecast Forecast Today konnte nicht abgefragt werden
-
@triple-m said in Daten aus Fronius Solarweb auslesen:
@strobelix
Das geänderte Blockly passt und funktioniert nur ich bekomme, auch schon mit der vorherigen Version, etliche Warnmeldungen im Protokoll, wie z.B.:Das sind noch alte Datenpunkte aus der ersten Version.
Da läuft ein Script, das den Token sucht, den es schon länger nicht mehr als Datenpunkt gibt.
Hast du das script doppelt laufen? Das alte solltest du abschalten -
@massiveattack said in Daten aus Fronius Solarweb auslesen:
Könntest du noch bitte die Fehlermeldungen ausbauen bzw nicht als error klassifizieren, wenn man kein premium hat?
javascript.0 2022-02-14 09:00:04.208 error script.js.Fronius: Solarweb Forecast Forecast Tomorrow konnte nicht abgefragt werden javascript.0 2022-02-14 09:00:02.204 error script.js.Fronius: Solarweb Forecast Forecast Today konnte nicht abgefragt werden
Kann ich machen.
Solange kannst du im blockly auch einfach alles mit „forecast“ deaktivieren -
-
Eigentlich läuft das Script nicht doppelt. Ich habe das Script nun nochmal gelöscht und komplett neu angelegt aber es kommen gleich wieder Warnungen.
2022-02-14 14:46:18.940 - info: javascript.0 (4697) Stop script script.js.common.Fronius_SolarWeb 2022-02-14 14:48:03.164 - info: javascript.0 (4697) Stop script script.js.common.Fronius 2022-02-14 14:48:08.115 - info: javascript.0 (4697) Start javascript script.js.common.Fronius 2022-02-14 14:48:08.121 - info: javascript.0 (4697) script.js.common.Fronius: registered 0 subscriptions and 0 schedules 2022-02-14 14:48:08.771 - info: javascript.0 (4697) script.js.common.Fronius: Solarweb Token erstellt 2022-02-14 14:50:00.004 - warn: javascript.0 (4697) getState "0_userdata.0.Solarweb.Token" not found (3) 2022-02-14 14:50:00.004 - warn: javascript.0 (4697) at Tagesdaten (script.js.common.Fronius_SolarWeb:219:20) 2022-02-14 14:50:00.004 - warn: javascript.0 (4697) at Object. (script.js.common.Fronius_SolarWeb:442:11) 2022-02-14 14:50:00.004 - warn: javascript.0 (4697) at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1313:34) 2022-02-14 14:50:00.004 - warn: javascript.0 (4697) at Job.invoke (/opt/iobroker/node_modules/node-schedule/lib/Job.js:168:15) 2022-02-14 14:50:00.004 - warn: javascript.0 (4697) at /opt/iobroker/node_modules/node-schedule/lib/Invocation.js:268:28 2022-02-14 14:50:00.004 - warn: javascript.0 (4697) at Timeout._onTimeout (/opt/iobroker/node_modules/node-schedule/lib/Invocation.js:228:7) 2022-02-14 14:50:00.004 - warn: javascript.0 (4697) at listOnTimeout (node:internal/timers:559:17) 2022-02-14 14:50:00.004 - warn: javascript.0 (4697) at processTimers (node:internal/timers:502:7) 2022-02-14 14:50:00.214 - warn: javascript.0 (4697) State "0_userdata.0.Solarweb.NeuerToken" not found 2022-02-14 14:50:00.215 - warn: javascript.0 (4697) at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1439:20) 2022-02-14 14:50:00.215 - warn: javascript.0 (4697) at callback (script.js.common.Fronius_SolarWeb:248:9) 2022-02-14 14:50:00.216 - warn: javascript.0 (4697) at Request._callback (/opt/iobroker/node_modules/iobroker.javascript/lib/request.js:27:17) 2022-02-14 14:50:00.216 - warn: javascript.0 (4697) at Request.self.callback (/opt/iobroker/node_modules/request/request.js:185:22) 2022-02-14 14:50:00.216 - warn: javascript.0 (4697) at Request.emit (node:events:520:28) 2022-02-14 14:50:00.216 - warn: javascript.0 (4697) at Request.emit (node:domain:475:12) 2022-02-14 14:50:00.216 - warn: javascript.0 (4697) at Request. (/opt/iobroker/node_modules/request/request.js:1154:10) 2022-02-14 14:50:00.216 - warn: javascript.0 (4697) at Request.emit (node:events:520:28) 2022-02-14 14:50:00.216 - warn: javascript.0 (4697) at Request.emit (node:domain:475:12) 2022-02-14 14:50:00.216 - warn: javascript.0 (4697) at IncomingMessage. (/opt/iobroker/node_modules/request/request.js:1076:12) 2022-02-14 14:50:00.216 - warn: javascript.0 (4697) at Object.onceWrapper (node:events:639:28) 2022-02-14 14:50:00.216 - warn: javascript.0 (4697) at IncomingMessage.emit (node:events:532:35) 2022-02-14 14:50:00.216 - warn: javascript.0 (4697) at IncomingMessage.emit (node:domain:475:12) 2022-02-14 14:50:00.216 - warn: javascript.0 (4697) at endReadableNT (node:internal/streams/readable:1346:12) 2022-02-14 14:50:00.216 - warn: javascript.0 (4697) at processTicksAndRejections (node:internal/process/task_queues:83:21)
EDIT:
Ich habe jetzt mal alle Script gestoppt aber trotzdem kommen noch die Meldungen. Kann es sein das ein Script läuft was aber nicht angezeigt wird? -
@triple-m said in Daten aus Fronius Solarweb auslesen:
EDIT:
Ich habe jetzt mal alle Script gestoppt aber trotzdem kommen noch die Meldungen. Kann es sein das ein Script läuft was aber nicht angezeigt wird?Gute Frage. Zumindest sieht es ja so aus, wenn du das so beschreibst.
Irgendwo ist da was versteckt -
@strobelix
Ich habe gestern Abend ein Backup von ioBroker zurückgespielt und seid dem sieht es besser aus. Heute morgen hatte ich nur diese Warnungen und Meldungen:2022-02-15 00:00:00.071 - warn: javascript.0 (468) You are assigning a number to the state "0_userdata.0.Solarweb.Previous.01_Day.Vergangene_Tageswerte_abrufen" which expects a boolean. Please fix your code to use a boolean or change the state type to number. This warning might become an error in future versions. 2022-02-15 00:00:00.077 - warn: javascript.0 (468) at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1439:20) 2022-02-15 00:00:00.077 - warn: javascript.0 (468) at script.js.common.Fronius_SolarWeb:253:5 2022-02-15 00:00:00.077 - warn: javascript.0 (468) at Object.result.each (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:819:29) 2022-02-15 00:00:00.077 - warn: javascript.0 (468) at Tag_reset (script.js.common.Fronius_SolarWeb:252:9) 2022-02-15 00:00:00.077 - warn: javascript.0 (468) at Object. (script.js.common.Fronius_SolarWeb:917:11) 2022-02-15 00:00:00.077 - warn: javascript.0 (468) at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1313:34) 2022-02-15 00:00:00.077 - warn: javascript.0 (468) at Job.invoke (/opt/iobroker/node_modules/node-schedule/lib/Job.js:168:15) 2022-02-15 00:00:00.077 - warn: javascript.0 (468) at /opt/iobroker/node_modules/node-schedule/lib/Invocation.js:268:28 2022-02-15 00:00:00.077 - warn: javascript.0 (468) at Timeout._onTimeout (/opt/iobroker/node_modules/node-schedule/lib/Invocation.js:228:7) 2022-02-15 00:00:00.077 - warn: javascript.0 (468) at listOnTimeout (internal/timers.js:554:17) 2022-02-15 00:00:00.077 - warn: javascript.0 (468) at processTimers (internal/timers.js:497:7) 2022-02-15 00:00:00.092 - info: javascript.0 (468) State value to set for "0_userdata.0.Solarweb.Previous.01_Day.Vergangene_Tageswerte_abrufen" has to be type "boolean" but received type "number" 2022-02-15 00:00:01.485 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 00:00:02.175 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Current Day - Keine Daten vorhanden 2022-02-15 00:30:01.164 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 00:30:02.178 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Current Day - Keine Daten vorhanden 2022-02-15 01:00:01.097 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 01:00:02.191 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Current Day - Keine Daten vorhanden 2022-02-15 01:30:02.229 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Current Day - Keine Daten vorhanden 2022-02-15 01:30:02.901 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 02:00:02.196 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Current Day - Keine Daten vorhanden 2022-02-15 02:00:02.431 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 02:30:02.200 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Current Day - Keine Daten vorhanden 2022-02-15 02:30:02.211 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 03:00:01.393 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 03:00:02.186 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Current Day - Keine Daten vorhanden 2022-02-15 03:30:01.904 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 04:00:01.939 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 04:30:01.407 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 05:00:01.377 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 05:30:02.873 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 06:00:01.681 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 06:30:01.722 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 07:00:01.431 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 07:30:01.424 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt 2022-02-15 08:00:01.599 - info: javascript.0 (468) script.js.common.Fronius_SolarWeb: Solarweb Token erstellt
-
@Strobelix @all
Hat noch jemand heute Morgen feststellen müssen, das die Monatswerte der Vormonate mit dem Wechsel zum März verschwunden sind?
Das Solarweb von Fronius funktioniert und da werden Werte angezeigt. Auch die Wochentag Werte sin da. Nur die Monatswerte Januar/Februar sind weg und für März wird auch noch nichts angezeigt.
Hat jemand ähnliche Probleme?
-
@jb_sullivan sagte in Daten aus Fronius Solarweb auslesen:
Hat jemand ähnliche Probleme?
Kann ich bestätigen.
Erst nach0_userdata.0.Solarweb.Current.05_Annual_Months.Aktuelle_Einzelmonatswerte_abrufen
waren sie wieder da.
Problem war bei allen vergangenen Werten so.Und woher kommt
0_userdata.0.Solarweb.undefined
?
Ist bei
Energy
gleich wie0_userdata.0.Solarweb.Previous.04_Month
, aberSaving
unterscheidet sich.
-
@negalein sagte in Daten aus Fronius Solarweb auslesen:
Erst nach 0_userdata.0.Solarweb.Current.05_Annual_Months.Aktuelle_Einzelmonatswerte_abrufen waren sie wieder da.
Das mit dem Button hat bei mir im ersten Anlauf nicht funktioniert. Habe es jetzt nochmal probiert und nun sind die Werte wieder da.