NEWS
Stromzähler per Sonoff ESP8266 auslesen
-
Ja genau, das ist mein Plan. Aktuell kann ich schon 2 Zähler mit einem esp auslesen.
Nur hätte ich gern für beide Zähler die Zählerstände:
00:00Uhr
Monatsanfang
Jahresanfang
Tagesverbrauch
Wochenverbrauch
MonatsverbrauchIst das möglich?
Gruß
Sangandi -
@sangandi Das ist möglich. Ich habe das im ioBroker mit einem Skript gelöst. Natürlich kannst du das auch in einem Skript auf dem ESP lösen, da bin ich allerdings überfragt, wie du die zwei Zähler trennst.
Ich finde es im ioBroker eleganter gelöst, da du alle Skripte an einem Platz hast. Die entsprechenden Datenpunkte habe ich mir als Objekte in 0_userdata angelegt.
-
Ich habe noch einmal ins Handbuch geschaut. Im Menü des Zählers gibt es den Eintrag "InF OFF (On)" "...kann der Datensatz an der INFO Schnittstelle Ein (On) oder aus (OFF) geschaltet werden."
Nun werden die meisten Daten auch übermittelt. Tagesverbrauch jedoch immer noch nicht, aber Hauptsache ich bekomme die aktuelle Lesitung
-
@sangandi Das müsste theoretisch möglich sein. Über den Parameter M stellst du den Zähler bzw. die Anzahl der Zähler ein.
Aber wie genau da bin ich ehrlich gesagt überfragt. So tief bin ich in das Script nie eingestiegen. Da wäre es sinnvoll mal im Discord Channel bei Tasmota nachzufragen. Dort sitzt der Entwickler des Scripts. -
Ich habe es soweit geschafft.
Zähler wird ausgelesen
im ESP32 zeigt Tasmota die Werte an und sendet an IOBroker.im Objekt SENSOR erhalte ich jedoch dass:
{
"Time": "2022-07-08T14:57:20",
"SML": {
"Total_in": 68055.5349,
"Power_curr": 854
},
"ESP32": {
"Temperature": 74.4
},
"TempUnit": "C"
}Was muss ich ändern, damit ich den aktuellen Bezug (Power_curr) und den Gesamtbezug (Total_in) einfach nur als Wert bekomme?
Oder muss ich in einem Skript den Inhalt zerlegen und "auswerten"? -
Ich habe den "Sensor" aus dem MQTT - Adapter genommen und nutze jetzt den
Sonoff - Adapter. Dort wird er korrekt dargestellt. -
@toki1973 Wie sieht dein Skript ITRON für Tasmota aus?
-
Ich versuche mich auch gerade am Tasmota-Zähler. Dafür verwende ich einen NodeMCU.
Der Infrarot-Sensor hat einen USB-A Ausgang.Sehe ich das richtig, dass die erste zeile im Script schon auf die GPIOs referenziert? Was muss ich dementsprechend in Tasmota konfigurieren? Nichts? Ich habe die beiden Datenanschlüsse an GPIO1 und GPIO3. Wenn ich Serial RX und TX belege, dann wird im Hauptmenu garnichts angezeigt, da heisst es RX1 ist bereits konfiguriert...oder irgendwie so. Ich habe auch mal im Script 1 und 3 vertauscht (da ich nicht weiss, welcher USB-Anschluss wohin auf dem Empfänger landet... leider kein Erfolg.
Via ioBroker Smartmeter Adapter funktioniert der Sensor problemlos.
Habt ihr noch Tips/ Anregungen?
>D >B =>sensor53 r >M 1 +3,1,s,0,9600,MT681 1,77070100010800ff@1000,Gesamtverbrauch,KWh,Total_in,3 1,770701000f0700ff@1,Leistung,W,Power_cur,0 1,77070100150700ff@1,Leistung P1,W,Power_p1,0 1,77070100290700ff@1,Leistung P2,W,Power_p2,0 1,770701003d0700ff@1,Leistung P3,W,Power_p3,0 1,77070100000009ff@#,Service ID,,Meter_id,0| #
Leider kann ich den Sensor nicht auseinandernehmen. Der scheint mir verklebt... Das ist vmt. ein Selbstbau IR-Sender/Empfänger mit 3D-Druck. Da das ganze Ding im ioBroker funktioniert, muss ich das doch nciht freileuchten, oder doch?
Ergänzung. Ich habe den Empfänger an 3,3v, GND, RX und TX angeschlossen. Oder läuft das Teil auf 5V?
-
@ralfth
Hi, sehr gut das Script. Hast du eventuell eine passende Visualisierung dazu, oder einen Link?
-
@uli-geins Hallo, ich habe das in Jarvis visualisiert.
Ich lege nicht sehr großen Wert auf eine "schicke" Visualisierung, obwohl das mit Jarvis sicherlich auch funktioniert. Ich verwende die Daten für Verbrauchs- und Temperaturstatistiken. Ich habe auch noch einen Kalender für Termine und Müll integriert. Ich bin da eher Purist was die smarte Steuerung des Hauses anbelangt.
VIS hatte ich mal versucht, allerdings ist mir das zu aufwendig gewesen. Wobei der Müllkalender in VIS gemacht wurde und als iFrame in Jarvis integriert wurde. -
Hallo zusammen erstmal an das Forum!
Ich bin fleissiger Leser und hab schon solch manch brauchbare Info hier gefunden!
Jetzt komme ich nicht weiter und denke, dass ich hier richtig aufgehoben bin.
Ich versuche, mit tasmota meinen smarten Stromzähler auszulesen.
Das klappt auch gut über das Webinterface.
Jedoch sind für meine Anwendung die mqtt-Daten interessanter. Diese werden jedoch von dem ESP8266 nur nach einem Neustart aktualisiert bzw. bereitgestellt.C:\Program Files (x86)\mosquitto>mosquitto_sub -h 192.168.1.133 -t tasmota/#
{"ip":"192.168.1.31","dn":"Tasmota","fn":["Tasmota",null,null,null,null,null,null,null],"hn":"tasmota_0DF0CF-4303","mac":"4417930DF0CF","md":"Generic","ty":0,"if":0,"ofln":"Offline","onln":"Online","state":["OFF","ON","TOGGLE","HOLD"],"sw":"9.2.0.3","t":"tasmota_0DF0CF","ft":"%prefix%/%topic%/","tp":["cmnd","stat","tele"],"rl":[0,0,0,0,0,0,0,0],"swc":[-1,-1,-1,-1,-1,-1,-1,-1],"swn":[null,null,null,null,null,null,null,null],"btn":[0,0,0,0],"so":{"4":0,"11":0,"13":0,"17":0,"20":0,"30":0,"68":0,"73":0,"82":0,"114":0},"lk":1,"lt_st":0,"sho":[0,0,0,0],"ver":1}
{"sn":{"Time":"2022-07-30T10:13:46","SML":{"Total_in":61.6,"Total_out":677.6891,"Power_curr":-1191,"Volt_p1":235.4,"Volt_p2":234.9,"Volt_p3":235.8,"Ampere_p1":1.66,"Ampere_p2":1.73,"Ampere_p3":1.93,"frequency":49.9}},"ver":1}
{"ip":"192.168.1.118","dn":"Tasmota","fn":["Tasmota",null,null,null,null,null,null,null],"hn":"tasmota_0D4704-1796","mac":"4417930D4704","md":"Generic","ty":0,"if":0,"ofln":"Offline","onln":"Online","state":["OFF","ON","TOGGLE","HOLD"],"sw":"9.2.0.3","t":"tasmota_0D4704","ft":"%prefix%/%topic%/","tp":["cmnd","stat","tele"],"rl":[0,0,0,0,0,0,0,0],"swc":[-1,-1,-1,-1,-1,-1,-1,-1],"swn":[null,null,null,null,null,null,null,null],"btn":[0,0,0,0],"so":{"4":0,"11":0,"13":0,"17":0,"20":0,"30":0,"68":0,"73":0,"82":0,"114":0},"lk":1,"lt_st":0,"sho":[0,0,0,0],"ver":1}
{"sn":{"Time":"2022-07-30T20:13:39","SML":{"Total_in":63.1,"Total_out":686.0649,"Power_curr":161,"Volt_p1":233.9,"Volt_p2":234.9,"Volt_p3":234.8,"Ampere_p1":0.70,"Ampere_p2":0.71,"Ampere_p3":0.86,"frequency":50.0}},"ver":1}Da für gewöhnlich das Problem eher vor dem Bildschirm sitzt: Hat jemand einen Rat für mich, wo ich da den Bock drinnen habe?
Bei Tasmota unter Logging habe ich schon diverse Telemetry-Periods getestet, alles ohne Erfolg ;-( .
Viele Grüße
Torsten -
@henni774 Mal abgesehen davon das du auf einer uralten Version von Tasmota unterwegs bist wäre es noch recht schön wenn du die Ausgabe in Code Tags packen würdest die man dann besser lesen kann.
Was steht in den Einstellungen unter "Telemetrieperiode" (Bei Logging der unterste Punkt)?
-
@chaot
Vielen Dank für Deine Antwort.
Bei den Einstellungen unter Telemetrieperiode habe ich aktuell 30, habe aber auch schon 10, 100 und 300 probiert.
Mein Script schaut so aus (ich hoffe, das passt so mit der Darstellung) :>D >B ->sensor53 r >M 1 +1,4,s,16,9600,SML 1,77070100010800ff@1000,Bezug Gesamt,kWh,Total_in,1 1,77070100020800ff@1000,Einspeisung,kWh,Total_out,4 1,77070100100700ff@1,Aktueller Verbrauch,W,Power_curr,16 1,77070100200700ff@1,Volt P1,V,Volt_p1,1 1,77070100340700ff@1,Volt P2,V,Volt_p2,1 1,77070100480700ff@1,Volt P3,V,Volt_p3,1 1,770701001f0700ff@1,Ampere P1,A,Ampere_p1,2 1,77070100330700ff@1,Ampere P2,A,Ampere_p2,2 1,77070100470700ff@1,Ampere P3,A,Ampere_p3,2 ;1,77070100510704ff@1,Phaseangle I-L1/U-L1,deg,phase_angle_p1,1 ;1,7707010051070fff@1,Phaseangle I-L27I-L2,deg,phase_angle_p2,1 ;1,7707010051071aff@1,Phaseangle I-L3/I-L3,deg,phase_angle_p3,1 1,770701000e0700ff@1,Frequenz,Hz,frequency,1 #
Die Datenabfrage dann so:
C:\Program Files (x86)\mosquitto>mosquitto_sub -h 192.168.1.133 -t tasmota/#
-
Eigenartiger Weise sind die Daten auf der Weboberfläche gefühlt sekündlich aktuell. Über mqtt kommen immer nur die Daten nach dem letzten Neustart des ESP.
Grüße
Torsten -
@henni774
Hast du JSON Export aktiviert?#ifndef USE_SML_M #define USE_SML_M #endif #ifndef USE_SML_SCRIPT_CMD #define USE_SML_SCRIPT_CMD #endif #ifndef USE_SCRIPT_WEB_DISPLAY #define USE_SCRIPT_WEB_DISPLAY #endif #ifndef USE_SCRIPT_JSON_EXPORT #define USE_SCRIPT_JSON_EXPORT #endif
Das dann im Script dazu:
>J ,"Verbrauch Tag":"%sd%" ,"Verbrauch Monat":"%smn%" ,"Verbrauch Jahr":"%syn%" ,"Zählerstand 0:00Uhr":"%2sm%" ,"Zählerstand Monatsanfang":"%2sma%" ,"Zählerstand Jahrenanfang":"%2sya%" ,"Kosten dieses Jahr":"%2yspr%"
Soweit ich mich erinnere habe ich das für MQTT gebraucht.
-
@chaot
Oh, ich glaube, das könnte zielführend werden, danke schön!
Wo führe die Aktivierung des JSON Exports durch? -
@henni774 Noch was gemerkt:
Bei mir läuft web log level auf "2"
Dann siehst du zumindest in der Konsolenansicht ob dort aktualisiert wird.Geh auch mal mit der Tasmotaversion auch über 10. Da gab es gerade bei den Scripts einige Veränderungen.
-
@henni774
Die Aktivierungen musst du beim Erstellen der Firmware angeben. Du hast ja auch SML aktiviert. Also in der userconfig -
@chaot
Besten Dank, ich werd mich da nachher mal drum kümmern -
@chaot
Hallo Chaote, bin jetzt auf Tasmota 12.0, Json Export ist drin. Aber derzeit ohne Besserung - die mqtt-Daten kommen nur einmal nach dem Neustart.
Wobei ich zu mqtt im Scipt nichts drinnen habe. Erklärt sich mir nicht, warum er dann am Anfang sendet ... .
Es ist zum Mäuse melken ... das aber erscheint mir komisch (kommt aus der Konsole):17:17:44.424 MQT: tele/tasmota_0D4704/STATE = {"Time":"2022-07-31T17:17:44","Uptime":"0T00:15:40","UptimeSec":940,"Heap":20,"SleepMode":"Dynamic","Sleep":50,"LoadAvg":25,"MqttCount":1,"Wifi":{"AP":1,"SSId":"o2-WLAN08","BSSId":"B0:EA:BC:FE:2C:A3","Channel":11,"Mode":"11n","RSSI":96,"Signal":-52,"LinkCount":1,"Downtime":"0T00:00:04"}}
Der mqtt-Zähler steht und bleibt auf 1 ....
Hier mal die user_config:
#ifndef _USER_CONFIG_OVERRIDE_H_ #define _USER_CONFIG_OVERRIDE_H_ #ifndef USE_SCRIPT #define USE_SCRIPT //# adds about 17k flash size, variable ram size #endif #ifdef USE_RULES #undef USE_RULES #endif #define USE_SML_M #undef STA_SSID1 #define STA_SSID1 "o2-WLAN08"// [Ssid1] Wifi SSID #undef STA_PASS1 #define STA_PASS1 "********" // [Password1] Wifi password #undef MQTT_HOST #define MQTT_HOST "192.168.1.133" // [MqttHost] #undef MQTT_PORT #define MQTT_PORT 1883 // [MqttPort] MQTT port (10123 on CloudMQTT) #undef MQTT_USER #define MQTT_USER "" // [MqttUser] Optional user #undef MQTT_PASS #define MQTT_PASS "" // [MqttPassword] Optional password #define USE_SCRIPT_WEB_DISPLAY #define USE_SCRIPT_JSON_EXPORT #define USE_EXPRESSION #define SUPPORT_IF_STATEMENT #ifndef USE_SML_SCRIPT_CMD #define USE_SML_SCRIPT_CMD #endif #endif