NEWS
Stromzähler per Sonoff ESP8266 auslesen
Stromzähler per Sonoff ESP8266 auslesen
-
so sollte es gehen...
;Tagesverbrauch
hr=hours
if chg[hr]>0
and hr==0
and v2>0
then
sm=v2
svars
endif
if upsecs%tper==0
then
sd=v2-sm
endif
;TagesverbrauchEinshr=hours
if chg[hr]>0
and hr==0
and v3>0
then
sme=v3
svars
endif
if upsecs%tper==0
then
sde=v3-sme
endif@testpaul999 hat leider auch nix gebracht.
Anbei nochmal meine ganze config.
>D rssi=0 s1="Tagesverbrauch: {m}<b><span style=>" v2=0 v3=0 hr=0 md=0 yr=0 ;Strom p:sm=0 sd=0 p:sme=0 sde=0 p:sma=0 smn=0 p:sya=0 syn=0 sspr=0.2599 yspr=0 ysgp=150.00 y€=0 >T v2=SML#Total_in v3=SML#Total_out rssi=Wifi#RSSI >B ->sensor53 r >S ;Tagesverbrauch hr=hours if chg[hr]>0 and hr==0 and v2>0 then sm=v2 svars endif if upsecs%tper==0 then sd=v2-sm endif ;Tagesverbraucheins hr=hours if chg[hr]>0 and hr==0 and v3>0 then sme=v3 svars endif if upsecs%tper==0 then sde=v3-sme endif ;Monatsverbrauch md=day if chg[md]>0 and md==1 and v2>0 then sma=v2 svars endif if upsecs%tper==0 then smn=v2-sma endif ;Jahresverbrauch yr=year if chg[yr]>0 and hr==0 and md==1 and v2>0 then sya=v2 svars endif if upsecs%tper==0 then syn=v2-sya ;Kosten yspr=syn*sspr+ysgp endif >J ,"Verbrauch Tag":"%sd%" ,"Einspeisung Tag":"%sde%" ,"Verbrauch Monat":"%smn%" ,"Verbrauch Jahr":"%syn%" ,"Zählerstand 0:00Uhr":"%2sm%" ,"ZählerstandEins 0:00Uhr":"%2sme%" ,"Zählerstand Monatsanfang":"%2sma%" ,"Zählerstand Jahrenanfang":"%2sya%" ,"Kosten dieses Jahr":"%2yspr%" >W WLAN Empfang: {m}%rssi% ============== Tagesverbrauch: {m} %2sd% KWh TagesverbrauchEins: {m} %2sde% KWh Monatsverbrauch: {m} %2smn% KWh Jahresverbrauch: {m} %2syn% KWh ============== Strom Preis/kWh: {m} %4sspr% € Strom Grundpreis: {m} %2ysgp% € -------------- Strom kosten lfd. Jahr:{m} %2yspr% € ============== Strom Zählerstände: aktuell: {m} %2v2% KWh 0:00 Uhr: {m} %2sm% KWh 0:00 UhrEins: {m} %2sme% KWh Monatsanfang: {m} %2sma% KWh Jahresanfang: {m} %2sya% KWh ============== >M 1 +1,13,s,1,9600,SML 1,77070100010800ff@1000,Zählerstand,KWh,Total_in,2 1,77070100020800ff@1000,Einspeisung,KWh,Total_out,2 1,77070100100700ff@1,Stromverbrauch,W,Power_curr,0 1,77070100100700ff@1000,Aktuell,kW,Actual_pow,3 1,7707010060320101@#,Meter Nr,,Meter_number,0 #
-
@testpaul999 hat leider auch nix gebracht.
Anbei nochmal meine ganze config.
>D rssi=0 s1="Tagesverbrauch: {m}<b><span style=>" v2=0 v3=0 hr=0 md=0 yr=0 ;Strom p:sm=0 sd=0 p:sme=0 sde=0 p:sma=0 smn=0 p:sya=0 syn=0 sspr=0.2599 yspr=0 ysgp=150.00 y€=0 >T v2=SML#Total_in v3=SML#Total_out rssi=Wifi#RSSI >B ->sensor53 r >S ;Tagesverbrauch hr=hours if chg[hr]>0 and hr==0 and v2>0 then sm=v2 svars endif if upsecs%tper==0 then sd=v2-sm endif ;Tagesverbraucheins hr=hours if chg[hr]>0 and hr==0 and v3>0 then sme=v3 svars endif if upsecs%tper==0 then sde=v3-sme endif ;Monatsverbrauch md=day if chg[md]>0 and md==1 and v2>0 then sma=v2 svars endif if upsecs%tper==0 then smn=v2-sma endif ;Jahresverbrauch yr=year if chg[yr]>0 and hr==0 and md==1 and v2>0 then sya=v2 svars endif if upsecs%tper==0 then syn=v2-sya ;Kosten yspr=syn*sspr+ysgp endif >J ,"Verbrauch Tag":"%sd%" ,"Einspeisung Tag":"%sde%" ,"Verbrauch Monat":"%smn%" ,"Verbrauch Jahr":"%syn%" ,"Zählerstand 0:00Uhr":"%2sm%" ,"ZählerstandEins 0:00Uhr":"%2sme%" ,"Zählerstand Monatsanfang":"%2sma%" ,"Zählerstand Jahrenanfang":"%2sya%" ,"Kosten dieses Jahr":"%2yspr%" >W WLAN Empfang: {m}%rssi% ============== Tagesverbrauch: {m} %2sd% KWh TagesverbrauchEins: {m} %2sde% KWh Monatsverbrauch: {m} %2smn% KWh Jahresverbrauch: {m} %2syn% KWh ============== Strom Preis/kWh: {m} %4sspr% € Strom Grundpreis: {m} %2ysgp% € -------------- Strom kosten lfd. Jahr:{m} %2yspr% € ============== Strom Zählerstände: aktuell: {m} %2v2% KWh 0:00 Uhr: {m} %2sm% KWh 0:00 UhrEins: {m} %2sme% KWh Monatsanfang: {m} %2sma% KWh Jahresanfang: {m} %2sya% KWh ============== >M 1 +1,13,s,1,9600,SML 1,77070100010800ff@1000,Zählerstand,KWh,Total_in,2 1,77070100020800ff@1000,Einspeisung,KWh,Total_out,2 1,77070100100700ff@1,Stromverbrauch,W,Power_curr,0 1,77070100100700ff@1000,Aktuell,kW,Actual_pow,3 1,7707010060320101@#,Meter Nr,,Meter_number,0 #
@milanissimo So langsam fällt mir nichts mehr ein.
-
@testpaul999 hat leider auch nix gebracht.
Anbei nochmal meine ganze config.
>D rssi=0 s1="Tagesverbrauch: {m}<b><span style=>" v2=0 v3=0 hr=0 md=0 yr=0 ;Strom p:sm=0 sd=0 p:sme=0 sde=0 p:sma=0 smn=0 p:sya=0 syn=0 sspr=0.2599 yspr=0 ysgp=150.00 y€=0 >T v2=SML#Total_in v3=SML#Total_out rssi=Wifi#RSSI >B ->sensor53 r >S ;Tagesverbrauch hr=hours if chg[hr]>0 and hr==0 and v2>0 then sm=v2 svars endif if upsecs%tper==0 then sd=v2-sm endif ;Tagesverbraucheins hr=hours if chg[hr]>0 and hr==0 and v3>0 then sme=v3 svars endif if upsecs%tper==0 then sde=v3-sme endif ;Monatsverbrauch md=day if chg[md]>0 and md==1 and v2>0 then sma=v2 svars endif if upsecs%tper==0 then smn=v2-sma endif ;Jahresverbrauch yr=year if chg[yr]>0 and hr==0 and md==1 and v2>0 then sya=v2 svars endif if upsecs%tper==0 then syn=v2-sya ;Kosten yspr=syn*sspr+ysgp endif >J ,"Verbrauch Tag":"%sd%" ,"Einspeisung Tag":"%sde%" ,"Verbrauch Monat":"%smn%" ,"Verbrauch Jahr":"%syn%" ,"Zählerstand 0:00Uhr":"%2sm%" ,"ZählerstandEins 0:00Uhr":"%2sme%" ,"Zählerstand Monatsanfang":"%2sma%" ,"Zählerstand Jahrenanfang":"%2sya%" ,"Kosten dieses Jahr":"%2yspr%" >W WLAN Empfang: {m}%rssi% ============== Tagesverbrauch: {m} %2sd% KWh TagesverbrauchEins: {m} %2sde% KWh Monatsverbrauch: {m} %2smn% KWh Jahresverbrauch: {m} %2syn% KWh ============== Strom Preis/kWh: {m} %4sspr% € Strom Grundpreis: {m} %2ysgp% € -------------- Strom kosten lfd. Jahr:{m} %2yspr% € ============== Strom Zählerstände: aktuell: {m} %2v2% KWh 0:00 Uhr: {m} %2sm% KWh 0:00 UhrEins: {m} %2sme% KWh Monatsanfang: {m} %2sma% KWh Jahresanfang: {m} %2sya% KWh ============== >M 1 +1,13,s,1,9600,SML 1,77070100010800ff@1000,Zählerstand,KWh,Total_in,2 1,77070100020800ff@1000,Einspeisung,KWh,Total_out,2 1,77070100100700ff@1,Stromverbrauch,W,Power_curr,0 1,77070100100700ff@1000,Aktuell,kW,Actual_pow,3 1,7707010060320101@#,Meter Nr,,Meter_number,0 #
Das ist mein Script, da klappt die Zählung de Einspeisung.
D
; rssi=0
v2=0
v3=0
hr=0
md=0
yr=0
min=0
da=0
; Strom 0:00 Uhr Wert
p:sm=0
sd=0
; Monat 1ter Tag
p:sma=0
smn=0
; 1.Tag Jahr
p:sya=0
syn=0
; Einspeisung
p:inm=0
ind=0
; Tarif je Einheit
sspr=0.2516
yspr=0
; Grundgebühr
ysgp=71.09
y€=0
T
v2=SML#DJ_TPWRIN
v3=SML#DJ_TPWROUT
;rssi=Wifi#RSSI
B
->sensor53 r
tper=11
S
; Tagesverbrauch&Einspeisung
hr=hours
min=mins
if chg[min]>0
and hr==23
and min==59
then
sm=v2
inm=v3
svars
endif
if upsecs%tper==0
then
sd=v2-sm
ind=v3-inm
endif
; Monatsverbrauch
da=day
hr=hours
min=mins
if chg[da]>0
and da==01
; and hr==8
; and min==09
then
sma=v2
svars
endif
if upsecs%tper==0
then
smn=v2-sma
endif
; Jahresverbrauch
yr=year
md=month
hr=hours
min=mins
if chg[yr]>0
and md==01
; and hr==00
; and min==01
then
sya=v2
svars
endif
if upsecs%tper==0
then
syn=v2-sya
endif
; Kosten
yspr=syn*sspr+ysgp
J
,"Verbrauch Tag":"%sd%"
,"Verbrauch Monat":"%smn%"
,"Verbrauch Jahr":"%syn%"
,"Einspeisung Tag":"%ind%"
,"Zählerstand 0:00Uhr":"%2sm%"
,"Zählerstand Monatsanfang":"%2sma%"
,"Zählerstand Jahrenanfang":"%2sya%"
,"Kosten dieses Jahr":"%2yspr%"
W
Zaehlernummer: {m} xxxxxxxxxxxxx
==============
Tagesverbrauch:{m} %2sd% KWh
Tageseinspeisung:{m} %2ind% KWh
Monatsverbrauch: {m} %2smn% KWh
Jahresverbrauch: {m} %2syn% KWh
==============
Strom Preis/kWh: {m} %4sspr% €
Strom Grundpreis: {m} %2ysgp% €
Stromkosten lfd. Jahr: {m} %2yspr% €
Strom Zählerstände:
aktuell: {m} %2v2% KWh
Bezug 0:00 Uhr: {m} %2sm% KWh
Einspeisung 0:00 Uhr: {m} %2inm% KWh
Monatsanfang: {m} %2sma% KWh
Jahresanfang: {m} %2sya% KWhM 1
+1,5,s,16,9600,SML
1,77070100010800ff@1000,Verbrauch,KWh,DJ_TPWRIN,2
1,77070100020800ff@1000,Einspeisung,KWh,DJ_TPWROUT,2
1,77070100100700ff@1,Akt.Verbrauch,W,DJ_TPWRCURR,2
1,=h==============
1,77070100000009ff@#,Zaehler ID,,Meter_number,0
1,=h==============
-
Hallo,
da mein Zähler leider die PIN nach glaube ich 240 Sekunden wieder "vergisst" wenn keine Eingabe mehr stattfindet möchte ich gerne eine LED am "optischen Taster" alle 120 Sekunden kurz blinken lassen.
Leider hatte ich bis jetzt keinen Erfolg das im Script einzufügen.
Alle Codebeispiele die ich gefunden habe beziehen sich auf Rules und die kann ich ja nicht parallel nutzen.Wie muss das Script dazu ausschauen?
Zur Zeit habe ich das:>D >B ->sensor53 r >M +1,13,s,1,9600,SML 1,77070100010800ff@1000,Verbrauch,KWh,Power_in,1 1,77070100100700ff@1,Akt. Verbrauch,W,Power_act,1 1,77070100240700ff@1,Wirkleistung L1,W,Power_p1,1 1,77070100380700ff@1,Wirkleistung L2,W,Power_p2,1 1,770701004c0700ff@1,Wirkleistung L3,W,Power_p3,1 # -
Hallo,
da mein Zähler leider die PIN nach glaube ich 240 Sekunden wieder "vergisst" wenn keine Eingabe mehr stattfindet möchte ich gerne eine LED am "optischen Taster" alle 120 Sekunden kurz blinken lassen.
Leider hatte ich bis jetzt keinen Erfolg das im Script einzufügen.
Alle Codebeispiele die ich gefunden habe beziehen sich auf Rules und die kann ich ja nicht parallel nutzen.Wie muss das Script dazu ausschauen?
Zur Zeit habe ich das:>D >B ->sensor53 r >M +1,13,s,1,9600,SML 1,77070100010800ff@1000,Verbrauch,KWh,Power_in,1 1,77070100100700ff@1,Akt. Verbrauch,W,Power_act,1 1,77070100240700ff@1,Wirkleistung L1,W,Power_p1,1 1,77070100380700ff@1,Wirkleistung L2,W,Power_p2,1 1,770701004c0700ff@1,Wirkleistung L3,W,Power_p3,1 # -
Hallo,
da mein Zähler leider die PIN nach glaube ich 240 Sekunden wieder "vergisst" wenn keine Eingabe mehr stattfindet möchte ich gerne eine LED am "optischen Taster" alle 120 Sekunden kurz blinken lassen.
Leider hatte ich bis jetzt keinen Erfolg das im Script einzufügen.
Alle Codebeispiele die ich gefunden habe beziehen sich auf Rules und die kann ich ja nicht parallel nutzen.Wie muss das Script dazu ausschauen?
Zur Zeit habe ich das:>D >B ->sensor53 r >M +1,13,s,1,9600,SML 1,77070100010800ff@1000,Verbrauch,KWh,Power_in,1 1,77070100100700ff@1,Akt. Verbrauch,W,Power_act,1 1,77070100240700ff@1,Wirkleistung L1,W,Power_p1,1 1,77070100380700ff@1,Wirkleistung L2,W,Power_p2,1 1,770701004c0700ff@1,Wirkleistung L3,W,Power_p3,1 # -
Es ist ein Easymeter Q3AA2274. Wenn ich das in der Anleitung richtig verstanden habe kann der Netzbetreiber bei der Bestellung der Zähler wählen ob er die Pin "vergisst" oder nicht und ist dann nicht mehr so einfach änderbar. Schon gar nicht durch den Endbenutzer. Evtl. vom "Profi" über die infrarote Eingabeschnittstelle die verplombt ist.
-
Es ist ein Easymeter Q3AA2274. Wenn ich das in der Anleitung richtig verstanden habe kann der Netzbetreiber bei der Bestellung der Zähler wählen ob er die Pin "vergisst" oder nicht und ist dann nicht mehr so einfach änderbar. Schon gar nicht durch den Endbenutzer. Evtl. vom "Profi" über die infrarote Eingabeschnittstelle die verplombt ist.
@da_ba_bw sagte in Stromzähler per Sonoff ESP8266 auslesen:
Easymeter Q3AA2274
https://www.easymeter.com/downloads/products/zaehler/Q3M/EDL12/BA_Easymeter_Q3M_603_2017-06-17.pdf
Seite 10 letzter Punkt "Schutzstatus" ist Standard auf ON. Wenn auf OFF ist der Spuk vorbei.Wenn nicht würde ich den Messtellenbetreiber kontaktieren und um Austausch bitte. Du zahlst ja auch einen nicht ganz geringen Beitrag für den smarten Zähler den du so nicht nutzen kannst.
Übrigens kannst du auch den Messtellenbetreiber frei wählen. Nur als Hinweis falls der sich bisschen blöd anstellen sollte. -
Danke für die Recherche! In dieser Anleitung fehlt leider der Hinweis dass das optional ist.
https://www.easymeter.com/downloads/products/zaehler/Q3A/Kurzanleitung-Q3A-Drehstrom-Zweirichtungszaehler.pdf
Hier auf Seite 2 steht " * Sofern Vorhanden". Und das ist es leider nicht. Diese beiden Menüpunkte fehlen.Werde mal nachfragen ob da eine Änderung möglich ist. Ich zahle direkt gar nichts für den Zähler, geht ja über den Stromanbieter. Ist auch nicht speziell als smarter Zähler bestellt sondern wurde kürzlich wegen den gesetzlichen Vorgaben getauscht. Deswegen sind die glaube auch nicht teurer geworden als mit dem alten Ferraris Zähler.
Aber mal unabhängig davon zurück zu meiner eigentlichen Frage.
Ist es generell möglich dort im Script noch solche Sachen wie LED blinken oder Ähnliches zu machen?Habe auch ein NodeMCU mit Magnetkontakt am Gaszähler hängen und würde dort gerne den Magnetstatus per Onboard-LED darstellen.
-
Danke für die Recherche! In dieser Anleitung fehlt leider der Hinweis dass das optional ist.
https://www.easymeter.com/downloads/products/zaehler/Q3A/Kurzanleitung-Q3A-Drehstrom-Zweirichtungszaehler.pdf
Hier auf Seite 2 steht " * Sofern Vorhanden". Und das ist es leider nicht. Diese beiden Menüpunkte fehlen.Werde mal nachfragen ob da eine Änderung möglich ist. Ich zahle direkt gar nichts für den Zähler, geht ja über den Stromanbieter. Ist auch nicht speziell als smarter Zähler bestellt sondern wurde kürzlich wegen den gesetzlichen Vorgaben getauscht. Deswegen sind die glaube auch nicht teurer geworden als mit dem alten Ferraris Zähler.
Aber mal unabhängig davon zurück zu meiner eigentlichen Frage.
Ist es generell möglich dort im Script noch solche Sachen wie LED blinken oder Ähnliches zu machen?Habe auch ein NodeMCU mit Magnetkontakt am Gaszähler hängen und würde dort gerne den Magnetstatus per Onboard-LED darstellen.
@da_ba_bw sagte in Stromzähler per Sonoff ESP8266 auslesen:
Werde mal nachfragen ob da eine Änderung möglich ist. Ich zahle direkt gar nichts für den Zähler, geht ja über den Stromanbieter. Ist auch nicht speziell als smarter Zähler bestellt sondern wurde kürzlich wegen den gesetzlichen Vorgaben getauscht. Deswegen sind die glaube auch nicht teurer geworden als mit dem alten Ferraris Zähler.
Kleiner Tip: Nö! Du wirst zum Wechsel gezwungen und ganz klein auf dem Brief den du bekommen hats steht dann das sich die jährlichen Betreiberkosten erhöhen werden. Anders gesagt wird deine Grundgebühr angehoben. Und das nicht zu knapp. Bei mir sind das immerhin 57€ im Jahr.
https://www.verbraucherzentrale.de/wissen/energie/preise-tarife-anbieterwechsel/smart-meter-die-neuen-stromzaehler-kommen-13275 -
@da_ba_bw sagte in Stromzähler per Sonoff ESP8266 auslesen:
Werde mal nachfragen ob da eine Änderung möglich ist. Ich zahle direkt gar nichts für den Zähler, geht ja über den Stromanbieter. Ist auch nicht speziell als smarter Zähler bestellt sondern wurde kürzlich wegen den gesetzlichen Vorgaben getauscht. Deswegen sind die glaube auch nicht teurer geworden als mit dem alten Ferraris Zähler.
Kleiner Tip: Nö! Du wirst zum Wechsel gezwungen und ganz klein auf dem Brief den du bekommen hats steht dann das sich die jährlichen Betreiberkosten erhöhen werden. Anders gesagt wird deine Grundgebühr angehoben. Und das nicht zu knapp. Bei mir sind das immerhin 57€ im Jahr.
https://www.verbraucherzentrale.de/wissen/energie/preise-tarife-anbieterwechsel/smart-meter-die-neuen-stromzaehler-kommen-13275Hallo an alle Tasmota script-checker hier!
Habe die Sache mit einem D1 mini realisiert, Zähler mit PIN vom Netzbetreiber gefüttert und es funktioniert auch alles soweit einwandfrei. Daten landen korrekt im MQTT.Womit ich kämpfe und bis jetzt leider überhaupt nicht weitergekommen bin: Der aktuelle Verbrauch wird im Webinterface ziemlich sekundengenau angezeigt, im MQTT landet aber nur alle 10 Sekunden ein aktualisierter Wert. Man kann die teleperiod ja nicht kleiner einstellen...
Den aktuellen Verbrauch (nur den, die anderen Werte würden auch jede Stunde reichen) bräuchte ich allerdings möglichst jede Sekunde bzw. bei Änderung sofort. Ich habe schon rumprobiert mit einem >S Bereich im Script komme aber mit dem Syntax und der Doku auf keinen grünen Zeig. Wie kommt man an die "Variable" (oder was auch immer das in Tasmota ist) ran die den aktuellen Wert hält (Power_curr im >M Teil vom Skript) und wie genau krieg ich das dann gepulished, wenns nicht anders geht kann das auch ein neues Topic sein.
Warum? Weil der aktuelle Verbrauch vom Zähler das Feedback für eine Nulleinspeiseregelung einer PV/Akku Anlage ist. Funktioniert zwar auch mit den Werten alle 10 Sek. allerdings halt mit entsprechender Verzögerung, unschön.
Tasmota 9.5 Kompiliert mit folgenden Settings:#ifndef USE_SCRIPT #define USE_SCRIPT #endif #ifndef USE_SML_M #define USE_SML_M #endif #ifndef USE_SML_SCRIPT_CMD #define USE_SML_SCRIPT_CMD #endif #ifdef USE_RULES #undef USE_RULES #endifUnd hier noch mein Script:
>D >B ->sensor53 r >M 1 +1,3,s,0,9600,SML 1,77070100010800ff@1000,Verbrauch,KWh,Total_in,4 1,77070100020800ff@1000,Einspeisung,KWh,Total_out,4 1,77070100100700ff@1,Leistung gesamt,W,Power_curr,0 1,77070100240700ff@1,Leistung L1,W,Power_p1,0 1,77070100380700ff@1,Leistung L2,W,Power_p2,0 1,770701004c0700ff@1,Leistung L3,W,Power_p3,0 1,77070100200700ff@1,Spannung L1,V,Volt_p1,1 1,77070100340700ff@1,Spannung L2,V,Volt_p2,1 1,77070100480700ff@1,Spannung L3,V,Volt_p3,1 #Wär für einen guten Tip dankbar.
-
Hallo an alle Tasmota script-checker hier!
Habe die Sache mit einem D1 mini realisiert, Zähler mit PIN vom Netzbetreiber gefüttert und es funktioniert auch alles soweit einwandfrei. Daten landen korrekt im MQTT.Womit ich kämpfe und bis jetzt leider überhaupt nicht weitergekommen bin: Der aktuelle Verbrauch wird im Webinterface ziemlich sekundengenau angezeigt, im MQTT landet aber nur alle 10 Sekunden ein aktualisierter Wert. Man kann die teleperiod ja nicht kleiner einstellen...
Den aktuellen Verbrauch (nur den, die anderen Werte würden auch jede Stunde reichen) bräuchte ich allerdings möglichst jede Sekunde bzw. bei Änderung sofort. Ich habe schon rumprobiert mit einem >S Bereich im Script komme aber mit dem Syntax und der Doku auf keinen grünen Zeig. Wie kommt man an die "Variable" (oder was auch immer das in Tasmota ist) ran die den aktuellen Wert hält (Power_curr im >M Teil vom Skript) und wie genau krieg ich das dann gepulished, wenns nicht anders geht kann das auch ein neues Topic sein.
Warum? Weil der aktuelle Verbrauch vom Zähler das Feedback für eine Nulleinspeiseregelung einer PV/Akku Anlage ist. Funktioniert zwar auch mit den Werten alle 10 Sek. allerdings halt mit entsprechender Verzögerung, unschön.
Tasmota 9.5 Kompiliert mit folgenden Settings:#ifndef USE_SCRIPT #define USE_SCRIPT #endif #ifndef USE_SML_M #define USE_SML_M #endif #ifndef USE_SML_SCRIPT_CMD #define USE_SML_SCRIPT_CMD #endif #ifdef USE_RULES #undef USE_RULES #endifUnd hier noch mein Script:
>D >B ->sensor53 r >M 1 +1,3,s,0,9600,SML 1,77070100010800ff@1000,Verbrauch,KWh,Total_in,4 1,77070100020800ff@1000,Einspeisung,KWh,Total_out,4 1,77070100100700ff@1,Leistung gesamt,W,Power_curr,0 1,77070100240700ff@1,Leistung L1,W,Power_p1,0 1,77070100380700ff@1,Leistung L2,W,Power_p2,0 1,770701004c0700ff@1,Leistung L3,W,Power_p3,0 1,77070100200700ff@1,Spannung L1,V,Volt_p1,1 1,77070100340700ff@1,Spannung L2,V,Volt_p2,1 1,77070100480700ff@1,Spannung L3,V,Volt_p3,1 #Wär für einen guten Tip dankbar.
Hallo zusammen,
ich habe das Problem das genau mein aktueller Stromverbrauch nicht geparsed werden kann. Ich sehe mit debug, dass die Meldungen korrekt reinkommen aber das Parsing scheint nicht zu funktionieren. Bei allen anderen Meldungen aber schon.
zum Beispiel lese ich folgendes:1,=h=========== 1,21.7.0(@1,Leistung L1,kW,Leistung_L1,2 1,41.7.0(@1,Leistung L2,kW,Leistung_L2,2 1,61.7.0(@1,Leistung L3,kW,Leistung_L3,2 1,=h=========== 1,=m 10+11+12*#1000 @1,Leistung errechnet,W,Leistung_avg,0 1,1.7.0(@1,Leistung ausgelesen,kW,current_actual,2
Die 1.7.0 gibt mir den aktuellen Verbrauch zurück und kommt auch in der Konsole korrekt an... erkennt jemand das Problem? Die andern Werte wie die 21.7 sind ja identisch vom Aufbau und werden korrekt ausgelesen...

Manchmal kommen dort Zahlen rein und stimmt auch mal aber die Meiste Zeit bleibt es entweder leer (0) oder stimmt nicht
Update: ich habe herausgefunden dass der Parser die 71.7.0 nimmt anstatt die 1.7.0 warum weiss ich auch nicht
Update2: ich habe mir jetzt beholfen in dem ich die Zeile davor auslese und dann bis zur Zeile danach springe in die zweiten Brackets das klappt ganz gut. Aber auch nur weil die Zeile davor generisch ist interne fixe Nummer... -
Das ist mein Script, da klappt die Zählung de Einspeisung.
D
; rssi=0
v2=0
v3=0
hr=0
md=0
yr=0
min=0
da=0
; Strom 0:00 Uhr Wert
p:sm=0
sd=0
; Monat 1ter Tag
p:sma=0
smn=0
; 1.Tag Jahr
p:sya=0
syn=0
; Einspeisung
p:inm=0
ind=0
; Tarif je Einheit
sspr=0.2516
yspr=0
; Grundgebühr
ysgp=71.09
y€=0
T
v2=SML#DJ_TPWRIN
v3=SML#DJ_TPWROUT
;rssi=Wifi#RSSI
B
->sensor53 r
tper=11
S
; Tagesverbrauch&Einspeisung
hr=hours
min=mins
if chg[min]>0
and hr==23
and min==59
then
sm=v2
inm=v3
svars
endif
if upsecs%tper==0
then
sd=v2-sm
ind=v3-inm
endif
; Monatsverbrauch
da=day
hr=hours
min=mins
if chg[da]>0
and da==01
; and hr==8
; and min==09
then
sma=v2
svars
endif
if upsecs%tper==0
then
smn=v2-sma
endif
; Jahresverbrauch
yr=year
md=month
hr=hours
min=mins
if chg[yr]>0
and md==01
; and hr==00
; and min==01
then
sya=v2
svars
endif
if upsecs%tper==0
then
syn=v2-sya
endif
; Kosten
yspr=syn*sspr+ysgp
J
,"Verbrauch Tag":"%sd%"
,"Verbrauch Monat":"%smn%"
,"Verbrauch Jahr":"%syn%"
,"Einspeisung Tag":"%ind%"
,"Zählerstand 0:00Uhr":"%2sm%"
,"Zählerstand Monatsanfang":"%2sma%"
,"Zählerstand Jahrenanfang":"%2sya%"
,"Kosten dieses Jahr":"%2yspr%"
W
Zaehlernummer: {m} xxxxxxxxxxxxx
==============
Tagesverbrauch:{m} %2sd% KWh
Tageseinspeisung:{m} %2ind% KWh
Monatsverbrauch: {m} %2smn% KWh
Jahresverbrauch: {m} %2syn% KWh
==============
Strom Preis/kWh: {m} %4sspr% €
Strom Grundpreis: {m} %2ysgp% €
Stromkosten lfd. Jahr: {m} %2yspr% €
Strom Zählerstände:
aktuell: {m} %2v2% KWh
Bezug 0:00 Uhr: {m} %2sm% KWh
Einspeisung 0:00 Uhr: {m} %2inm% KWh
Monatsanfang: {m} %2sma% KWh
Jahresanfang: {m} %2sya% KWhM 1
+1,5,s,16,9600,SML
1,77070100010800ff@1000,Verbrauch,KWh,DJ_TPWRIN,2
1,77070100020800ff@1000,Einspeisung,KWh,DJ_TPWROUT,2
1,77070100100700ff@1,Akt.Verbrauch,W,DJ_TPWRCURR,2
1,=h==============
1,77070100000009ff@#,Zaehler ID,,Meter_number,0
1,=h==============
Vielen Dank nochmal hab mein Fehler erkannt. Läuft jetzt auch bei mir prima danke

-
Vielen Dank nochmal hab mein Fehler erkannt. Läuft jetzt auch bei mir prima danke

Ich habe vor 2 Tagen begonnen meine Leistung mit Grafana darzustellen. Das ist übrigens für alle interessant, die eine Photovoltaik mit Batterie planen. Man kann sehr gut die Spitzenlastzeiten ermitteln. Dabei fielen mir allerdings grobe Ausreiser auf, wie Leistungswerte im 6-stelligen Bereich. Die konnte ich durch eine entsprechende Abfrage eliminieren. Aber meine Neugier war geweckt und ich schaute bei dem aktuellen Zählerstand auf Entsprechungen. Ich konnte zwar noch keine direkt finden, allerdings fand ich Zählerstandswerte, die unterhalb des letzten Wertes lagen. Ich frage mich jetzt, wo diese Werte herkommen.
Meine Hard- und Softwarekonfiguration:
- Zähler eHZ-HW8e
- Volkszähler
- ESP 8266 mit Tasmota 8.1.0.4
- SONOFF-Adapter
Hat jemand ähnliche Beobachtunge gemacht, bzw. hat dafür evtl. eine Erklärung?
-
@ralfth ich kann mir nur vorstellen, dass diese beim fehlerhaften Parsen zustande kommen. Man müsste erstmal die Rohdaten auslesen mit sensors d1 Dann kannst du schauen ob du auch nachden korrekten Daten schaust und vll nicht doch noch eine andere Zahl mit drin hast.
-
@ralfth ich kann mir nur vorstellen, dass diese beim fehlerhaften Parsen zustande kommen. Man müsste erstmal die Rohdaten auslesen mit sensors d1 Dann kannst du schauen ob du auch nachden korrekten Daten schaust und vll nicht doch noch eine andere Zahl mit drin hast.
@danielbroker86 Danke für die Info. Der Fehler kommt mir zu selten und größeren Abständen vor, als dass ich jetzt diesen Aufwand investieren möchte. Ich filtere diese unplausiblen Werte einfach aus.
-
@danielbroker86 Danke für die Info. Der Fehler kommt mir zu selten und größeren Abständen vor, als dass ich jetzt diesen Aufwand investieren möchte. Ich filtere diese unplausiblen Werte einfach aus.
@ralfth auch ne Möglichkeit

-
Ich habe es jetzt nach langen Versuchen hingebracht das der Zähler Rohdaten liefert.
Jetzt bräuchte ich Hilfe bei der Aufschlüsselung:13:55:29.529 : 77 07 01 00 60 32 04 04 01 01 01 01 03 04 22 01 01 01 63 32 0d 00 76 05 00 44 01 d8 62 00 62 00 72 63 02 01 71 01 63 5a 13:55:29.578 : 77 07 ff ff ff ff ff ff 0b 0a 01 45 46 52 20 02 cf 82 08 07 01 00 62 0a ff ff 72 62 01 64 16 ab 4a f1 06 13:55:29.580 : 77 07 01 00 60 32 01 01 01 01 01 01 04 45 46 52 01 13:55:29.628 : 77 07 01 00 60 01 00 ff 01 01 01 01 0b 0a 01 45 46 52 20 02 cf 82 08 01 13:55:29.631 : 77 07 01 00 01 08 00 ff 64 1c 00 04 72 62 01 64 16 ab 4a 62 1e 52 ff 64 2d af 9a 01 13:55:29.679 : 77 07 01 00 02 08 00 ff 01 72 62 01 64 16 ab 4a 62 1e 52 ff 62 00 01 13:55:29.681 : 77 07 01 00 10 07 00 ff 01 01 62 1b 52 00 53 05 f3 01 13:55:29.728 : 77 07 01 00 20 07 00 ff 01 01 62 23 52 ff 63 09 2e 01 13:55:29.731 : 77 07 01 00 34 07 00 ff 01 01 62 23 52 ff 63 09 45 01 13:55:29.733 : 77 07 01 00 48 07 00 ff 01 01 62 23 52 ff 63 09 30 01 13:55:29.778 : 77 07 01 00 1f 07 00 ff 01 01 62 21 52 fe 62 e9 01 13:55:29.780 : 77 07 01 00 33 07 00 ff 01 01 62 21 52 fe 63 01 2d 01 13:55:29.783 : 77 07 01 00 47 07 00 ff 01 01 62 21 52 fe 62 9e 01 13:55:29.829 : 77 07 01 00 51 07 01 ff 01 01 62 08 52 00 52 76 01 13:55:29.831 : 77 07 01 00 51 07 02 ff 01 01 62 08 52 00 53 00 ec 01 13:55:29.879 : 77 07 01 00 51 07 04 ff 01 01 62 08 52 00 52 03 01 13:55:29.881 : 77 07 01 00 51 07 0f ff 01 01 62 08 52 00 53 01 58 01 13:55:29.883 : 77 07 01 00 51 07 1a ff 01 01 62 08 52 00 53 01 66 01 13:55:29.929 : 77 07 01 00 0e 07 00 ff 01 01 62 2c 52 ff 63 01 f3 01 13:55:29.931 : 77 07 01 00 00 02 00 00 01 01 01 01 06 30 33 2e 30 30 01 13:55:29.934 : 77 07 01 00 60 5a 02 01 01 01 01 01 03 42 bd 01 13:55:29.979 : 77 07 01 00 61 61 00 00 01 01 01 01 03 00 00 01 13:55:29.981 : 77 07 01 00 60 32 01 04 01 01 01 01 08 50 31 2e 32 2e 31 32 01 13:55:30.598 : 77 07 01 00 60 32 01 01 01 01 01 01 04 45 46 52 01 13:55:30.600 : 77 07 01 00 60 01 00 ff 01 01 01 01 0b 0a 01 45 46 52 20 02 cf 82 08 01 13:55:30.647 : 77 07 01 00 01 08 00 ff 64 1c 00 04 72 62 01 64 16 ab 4b 62 1e 52 ff 64 2d af 9e 01 13:55:30.696 : 77 07 01 00 02 08 00 ff 01 72 62 01 64 16 ab 4b 62 1e 52 ff 62 00 01 13:55:30.699 : 77 07 01 00 10 07 00 ff 01 01 62 1b 52 00 53 05 e9 01 13:55:30.701 : 77 07 01 00 20 07 00 ff 01 01 62 23 52 ff 63 09 30 01 13:55:30.746 : 77 07 01 00 34 07 00 ff 01 01 62 23 52 ff 63 09 44 01 13:55:30.749 : 77 07 01 00 48 07 00 ff 01 01 62 23 52 ff 63 09 30 01 13:55:30.751 : 77 07 01 00 1f 07 00 ff 01 01 62 21 52 fe 62 ea 01 13:55:30.796 : 77 07 01 00 33 07 00 ff 01 01 62 21 52 fe 63 01 2e 01 13:55:30.799 : 77 07 01 00 47 07 00 ff 01 01 62 21 52 fe 62 9e 01 13:55:30.801 : 77 07 01 00 51 07 01 ff 01 01 62 08 52 00 52 76 01 13:55:30.847 : 77 07 01 00 51 07 02 ff 01 01 62 08 52 00 53 00 ec 01 13:55:30.850 : 77 07 01 00 51 07 04 ff 01 01 62 08 52 00 52 03 01 13:55:30.896 : 77 07 01 00 51 07 0f ff 01 01 62 08 52 00 53 01 58 01 13:55:30.898 : 77 07 01 00 51 07 1a ff 01 01 62 08 52 00 53 01 66 01 13:55:30.900 : 77 07 01 00 0e 07 00 ff 01 01 62 2c 52 ff 63 01 f3 01 13:55:30.947 : 77 07 01 00 00 02 00 00 01 01 01 01 06 30 33 2e 30 30 01 13:55:30.949 : 77 07 01 00 60 5a 02 01 01 01 01 01 03 42 bd 01 13:55:30.951 : 77 07 01 00 61 61 00 00 01 01 01 01 03 00 00 01 13:55:30.996 : 77 07 01 00 60 32 01 04 01 01 01 01 08 50 31 2e 32 2e 31 32 01Teilweise erfolgreich:
--- 7707010060320404 01 01 01 01 03 04 22 01 01 01 63 32 0d 00 76 05 00 44 01 d8 62 00 62 00 72 63 02 01 71 01 63 5a --- 7707ffffffffffff 0b 0a 01 45 46 52 20 02 cf 82 08 07 01 00 62 0a ff ff 72 62 01 64 16 ab 4a f1 06 Zahlernummer 7707010060320101 01 01 01 01 04 45 46 52 01 --- 77070100600100ff 01 01 01 01 0b 0a 01 45 46 52 20 02 cf 82 08 01 Verbrauch 77070100010800ff 64 1c 00 04 72 62 01 64 16 ab 4a 62 1e 52 ff 64 2d af 9a 01 --- 77070100020800ff 01 72 62 01 64 16 ab 4a 62 1e 52 ff 62 00 01 Aktuell 77070100100700ff 01 01 62 1b 52 00 53 05 f3 01 Spannung L1 77070100200700ff 01 01 62 23 52 ff 63 09 2e 01 Spannung L2 77070100340700ff 01 01 62 23 52 ff 63 09 45 01 Spannung L3 77070100480700ff 01 01 62 23 52 ff 63 09 30 01 Strom L1 770701001f0700ff 01 01 62 21 52 fe 62 e9 01 Strom L2 77070100330700ff 01 01 62 21 52 fe 63 01 2d 01 Strom L3 77070100470700ff 01 01 62 21 52 fe 62 9e 01 --- 77070100510701ff 01 01 62 08 52 00 52 76 01 --- 77070100510702ff 01 01 62 08 52 00 53 00 ec 01 --- 77070100510704ff 01 01 62 08 52 00 52 03 01 --- 7707010051070fff 01 01 62 08 52 00 53 01 58 01 --- 7707010051071aff 01 01 62 08 52 00 53 01 66 01 Frequenz 770701000e0700ff 01 01 62 2c 52 ff 63 01 f3 01 --- 7707010000020000 01 01 01 01 06 30 33 2e 30 30 01 --- 77070100605a0201 01 01 01 01 03 42 bd 01 --- 7707010061610000 01 01 01 01 03 00 00 01 --- 7707010060320104 01 01 01 01 08 50 31 2e 32 2e 31 32 01 --- 7707010060320101 01 01 01 01 04 45 46 52 01 --- 77070100600100ff 01 01 01 01 0b 0a 01 45 46 52 20 02 cf 82 08 01 --- 77070100010800ff 64 1c 00 04 72 62 01 64 16 ab 4b 62 1e 52 ff 64 2d af 9e 01 --- 77070100020800ff 01 72 62 01 64 16 ab 4b 62 1e 52 ff 62 00 01 --- 77070100100700ff 01 01 62 1b 52 00 53 05 e9 01 --- 77070100200700ff 01 01 62 23 52 ff 63 09 30 01 --- 77070100340700ff 01 01 62 23 52 ff 63 09 44 01 --- 77070100480700ff 01 01 62 23 52 ff 63 09 30 01 --- 770701001f0700ff 01 01 62 21 52 fe 62 ea 01 --- 77070100330700ff 01 01 62 21 52 fe 63 01 2e 01 --- 77070100470700ff 01 01 62 21 52 fe 62 9e 01 --- 77070100510701ff 01 01 62 08 52 00 52 76 01 --- 77070100510702ff 01 01 62 08 52 00 53 00 ec 01 --- 77070100510704ff 01 01 62 08 52 00 52 03 01 --- 7707010051070fff 01 01 62 08 52 00 53 01 58 01 --- 7707010051071aff 01 01 62 08 52 00 53 01 66 01 --- 770701000e0700ff 01 01 62 2c 52 ff 63 01 f3 01 --- 7707010000020000 01 01 01 01 06 30 33 2e 30 30 01 --- 77070100605a0201 01 01 01 01 03 42 bd 01 --- 7707010061610000 01 01 01 01 03 00 00 01 --- 7707010060320104 01 01 01 01 08 50 31 2e 32 2e 31 32 01@chaot
Hey ich hab den selben Zähler "EFR SGM-C4 4A920L", PIN eingegeben und PIN Sperre entfernt, der Zähler zeigt jetzt analog die aktuelle Watt Leistung an.Zum Problem ich habe auch die fertige Platine aus ebay, soweit alles zusammengelötet und an den WT32-ETH01 (da kein WLAN am Zähler) angeschlossen, dein Script kopiert:
>D >B ->sensor53 r >M 1 +1,12,s,1,9600,SML 1,77070100010800ff@1000,Zählerstand,KWh,Total_in,3 1,77070100020800ff@1000,Einspeisung,KWh,Total_out,3 1,77070100100700ff@1,Stromverbrauch,W,Power_curr,0 1,=h=================| 1,77070100200700ff@1,Spannung L1,V,Volt_p1,1 1,77070100340700ff@1,Spannung L2,V,Volt_p2,1 1,77070100480700ff@1,Spannung L3,V,Volt_p3,1 1,=h=================| 1,770701001f0700ff@1,Strom L1,A,Ampere_p1,1 1,77070100330700ff@1,Strom L2,A,Ampere_p2,1 1,77070100470700ff@1,Strom L3,A,Ampere_p3,1 1,=h=================| 1,770701000e0700ff@1,Netzfrquenz,Hz,Freq,0 1,=h=================| #Allerdings werden keine Werte angezeigt, bei der Fehlersuche wollte ich starten, ob überhaupt was vom Sensor via Serial (TX/RX) ankommt? Unter Console fand ich folgenden Eintrag:
APP: Serial logging disabledich hab den folgenden Befehl abgesendet:
CMD: SerialLog 4 RSL: RESULT = {"SerialLog":{"4":{"Active":"4"}}}Leider ohne Ergebnis.

Sollten hier Daten auftauchen oder muss ich auch was am Script ändern?
Könnte es auch sein, dass der Sensor zu ungenau am Zähler positioniert ist?
Kann man hier etwas hin und herschieben, dann sollte man ja unmittelbar was im Log bzw. unter Console sehen?
Oder muss ich die IR Schnittstelle am Zähler erst aktivieren?Vielen Dank.
-
@chaot
Hey ich hab den selben Zähler "EFR SGM-C4 4A920L", PIN eingegeben und PIN Sperre entfernt, der Zähler zeigt jetzt analog die aktuelle Watt Leistung an.Zum Problem ich habe auch die fertige Platine aus ebay, soweit alles zusammengelötet und an den WT32-ETH01 (da kein WLAN am Zähler) angeschlossen, dein Script kopiert:
>D >B ->sensor53 r >M 1 +1,12,s,1,9600,SML 1,77070100010800ff@1000,Zählerstand,KWh,Total_in,3 1,77070100020800ff@1000,Einspeisung,KWh,Total_out,3 1,77070100100700ff@1,Stromverbrauch,W,Power_curr,0 1,=h=================| 1,77070100200700ff@1,Spannung L1,V,Volt_p1,1 1,77070100340700ff@1,Spannung L2,V,Volt_p2,1 1,77070100480700ff@1,Spannung L3,V,Volt_p3,1 1,=h=================| 1,770701001f0700ff@1,Strom L1,A,Ampere_p1,1 1,77070100330700ff@1,Strom L2,A,Ampere_p2,1 1,77070100470700ff@1,Strom L3,A,Ampere_p3,1 1,=h=================| 1,770701000e0700ff@1,Netzfrquenz,Hz,Freq,0 1,=h=================| #Allerdings werden keine Werte angezeigt, bei der Fehlersuche wollte ich starten, ob überhaupt was vom Sensor via Serial (TX/RX) ankommt? Unter Console fand ich folgenden Eintrag:
APP: Serial logging disabledich hab den folgenden Befehl abgesendet:
CMD: SerialLog 4 RSL: RESULT = {"SerialLog":{"4":{"Active":"4"}}}Leider ohne Ergebnis.

Sollten hier Daten auftauchen oder muss ich auch was am Script ändern?
Könnte es auch sein, dass der Sensor zu ungenau am Zähler positioniert ist?
Kann man hier etwas hin und herschieben, dann sollte man ja unmittelbar was im Log bzw. unter Console sehen?
Oder muss ich die IR Schnittstelle am Zähler erst aktivieren?Vielen Dank.
-
@m4 Die Positionierung muss recht genau sein.
Bei mir kam am Anfang dazu dass ich scheinbar die Ein- und Ausgangsleitungen verwechselt hatte.@chaot
super danke für die Info scho mal.Sensor <-> ESP
RX <-> TX
TX <-> RXsoweit hätt ich's, allerdings hat der WT32-ETH01 einmal RX0 und TX0 sowie RXD und TXD da bin ich mir noch nicht sicher welcher Anschluss der Richtige ist. zumindest hat über RX0/TX0 das flashen schon mal geklappt.
Dann schieb ich den Sensor mal hin und her und schau parallel in die Console ab sich was "rührt".