NEWS
Temperatur aus JSON auslesen
-
Hallo,
ich bin ganz neu in dem Thema Mqtt-ioBroker.
Ich habe mir den ioBroker mit dem Modul MQTT-Adapter (auf Server Konfiguriert) auf einem Raspi3 installiert.
Als Aktor habe ich ein Sonoff-Basic mit der Tasmota Firmware.
Das läuft auch soweit, nur leider bekomme ich die Daten aus dem Sonoff-Modul fast alle im JSON-Format.
Welches wie für die Temperatur-Sensoren in der Variable "SENSOR" zu finden ist und wie folgt aussieht:
{"Time":"2017-05-19T11:33:10", "DS18x20":{"DS1":{"Type":"DS18B20", "Address":"28FFB2AD621603FE", "Temperature":19.8}, "DS2":{"Type":"DS18B20", "Address":"28FF598A621603A2", "Temperature":13.5}}, "TempUnit":"C"}
Jetzt wäre meine Frage, wie ich die beiden Temperaturen in einzelne Variablen bekomme?
Soweit ich das bis jetzt verstanden habe muss ich irgendwo einen Code hinschreiben, der das irgendwie auseinander fummelt und dann z.B. in die Var Temp1 und Temp2 schreibt…
-
…muss ich irgendwo einen Code hinschreiben, der das irgendwie auseinander fummelt und dann z.B. in die Var Temp1 und Temp2 schreibt... `
Ja, im Javascript-Adapter läßt sich der JSON-String "auseinander fummeln".Unter der Annahme, dass sich der JSON-String in einem Datenpunkt des MQTT-Adapters befindet, könnte das Skript so aussehen (oder so ähnlich):
var idJSON = 'mqtt.0.SENSOR'; // Datenpunkt-ID mit JSON-String var Temp1; var Temp2; function JSONtoTemp(json) { var obj = JSON.parse(json); Temp1 = obj.DS18x20.DS1.Temperature; Temp2 = obj.DS18x20.DS2.Temperature; log('DS1: ' + Temp1 + ' °C, DS2: ' + Temp2 + ' °C'); } JSONtoTemp(getState(idJSON).val); // Script start on(idJSON, function(dp) { // triggern bei Wertänderung JSONtoTemp(dp.state.val); });
-
Hey,
im Log bekomme ich schon schön die beiden Temperaturen angezeigt,
aber leider bekomme ich im MQTT-Server noch keinen Datenpunkt mit den Variablen Temp1 und Temp2.
Muss ich da auch noch etwas machen??
–-edit---
danke, musste noch eine setState mit einbauen....
kann ich mit dem script nur Temperaturen so zerlegen oder auch andere informationen wie z.B. batteriespannung und wlan signalstärke,
da ja im script JSON to Temp....?
-
aber leider bekomme ich im MQTT-Server noch keinen Datenpunkt mit den Variablen Temp1 und Temp2.
Muss ich da auch noch etwas machen?? `
Ja, die beiden Datenpunkte vom Typ Zahl müssen noch im Admin-Reiter "Objekte" nach Selektion von mqtt.0 http://www.iobroker.net/?page_id=5495&lang=de#6hinzufuegen werden. Nachdem die Datenpunkte erzeugt sind, muss das Skript erweitert werden:var idJSON = 'mqtt.0.SENSOR'; // Datenpunkt-ID mit JSON-String var idTemp1 = 'mqtt.0.Temperatur1'; var idTemp2 = 'mqtt.0.Temperatur2'; ...
Innerhalb der Funktion das log() ersetzen durch:
... setState(idTemp1, Temp1); setState(idTemp2, Temp2); }
-
kann ich mit dem script nur Temperaturen so zerlegen oder auch andere informationen wie z.B. batteriespannung und wlan signalstärke, `
Ja, wenn der JSON-String die gewünschten Informationen enthält. Jeder JSON-String ist anders aufgebaut; man muss also die Objekt-Struktur darin erkennen, um zum gewünschten Wert zu kommen. Dafür gibt es http://jsonviewer.stack.hu/. -
Hab da nochmal eine frage,
es läuft soweit alles, nur ist mir aufgefallen
wenn eine Temperatur z.B 24,0°C ist
wird mir aber nur 24 angezeigt und nicht 24,0.
Bei 24,1 wird mir auch 24,1 angezeigt.
Gibt es da noch einen Trick wie man sich auch die ,0 anzeigen lassen kann?
Im JSON wird auch 24,0 übertragen!?
-
Hab da nochmal eine frage,
es läuft soweit alles, nur ist mir aufgefallen
wenn eine Temperatur z.B 24,0°C ist
wird mir aber nur 24 angezeigt und nicht 24,0.
Bei 24,1 wird mir auch 24,1 angezeigt.
Gibt es da noch einen Trick wie man sich auch die ,0 anzeigen lassen kann?
Im JSON wird auch 24,0 übertragen!? `
wo moechtest du das drin visualisieren ?
Die objecten runden immer ab, in vis kannst du im widget angeben wieviel stellen immer hinterm comma gezeigt werden muessen.
So habe ich auch diese view hier gebaut:
- Dutch
-
Hey,
in der Vis ist das ja Problemlos möglich,
aber ich habe noch ein ESP8266 mit LCD-Display,
das dann eben nur 24 °C anzeigt, dachte man könnte da noch etwas am Script ändern….
-
… ich habe noch ein ESP8266 mit LCD-Display, das dann eben nur 24 °C anzeigt, dachte man könnte da noch etwas am Script ändern.... `
An das LCD-Display als String mit Wert.toFixed(1) ausgeben. -
Wäre ne möglichkeit, aber dann müsste ich das koplette ESP-Programm ändern,
denn es werden char an das LCD-geschickt.
Kann ich da nix im Javascript beim ioBroker ändern?
Wäre für mich einfacher.
Hab beim ESP-Display schon ehwigkeiten gebraucht, bis ich es hinbekommen habe
zwei Topics anzeigen zu lassen….
-
Kann ich da nix im Javascript beim ioBroker ändern? `
Wie gelangen die Zeichen von ioBroker an das ESP8266 ? Das Wandeln mit Wert.toFixed(1) ist Javascript-Code für ioBroker-JS-Adapter.. -
Wenn die beiden Datenpunkte idTemp1 und idTemp2 nur zur Anzeige dienen, ändere den Typ von 'number' in 'string' und ergänze das setState
... setState(idTemp1, Temp1.toFixed(1) + ' °C'); setState(idTemp2, Temp2.toFixed(1) + ' °C'); }
-
Besten Dank!!
Hab beim ioBroker JS das ".toFixed(1)" nachgetragen und damit funktioniert es wunderbar!
Das ESP8266-Display-Modul holt sich die Topic via MQTT-Callback
und die Callback Daten werden als char ans I2C-Display gereicht.
-
Ich denke, das könnte hilfreich sein: https://jsonformatter-online.com/
-
Hab da nochmal eine frage,
Die objecten runden immer ab, in vis kannst du im widget angeben wieviel stellen immer hinterm comma gezeigt werden muessen.
- Dutch
Hi,
ich muss das alte Thema nochmal aufgreifen. Welches Widget nutzt du dafür? Bei mir kann ich keine Kommastellen ausgeben bzw habe die Auswahl nicht. Ich nutze zum Anzeigen von Temperten Basic Strick dort gibt es aber das Feld erweitert mit den Komma stellen nicht? Gerade in Bezug auf Xiaomi dort werden mir 2 komme stellen ausgegeben aber es reicht eine
Grüße
Clemens
- Dutch
-
@feuer001
Leider muss ich nochmal fragen, ich habe die ganze Zeit dieses Script benutzt um Temperaturen aus einem JSON auszulesen, was auch sehr lange Zeit funktioniert hat. Nach einem defekt meiner Speicherkarte muss ich jetzt leider alles neu einrichten und auch alle meine Scripts neu erstellen. Jetzt habe ich dieses Forum wiedergefunden wo damals schonmal fragen musste. Und da ich jetzt auch auf den aktuellen iobroker aktualisiert habe, läuft leider dieses Script nicht mehr. Könnte vielleicht einer nochmal so nett sein und mir nochmals helfen??
Gruß
Feuer001 -
@feuer001-0 sagte in Temperatur aus JSON auslesen:
läuft leider dieses Script nicht mehr.
Die drei Datenpunkte vom Typ "string" mit den folgenden IDs exisitieren?
const idJSON = 'mqtt.0.SENSOR'; // Datenpunkt-ID mit JSON-String const idTemp1 = 'mqtt.0.Temperatur1'; const idTemp2 = 'mqtt.0.Temperatur2'; function JSONtoTemp(json) { let obj = JSON.parse(json); let Temp1 = obj.DS18x20.DS1.Temperature; let Temp2 = obj.DS18x20.DS2.Temperature; setState(idTemp1, Temp1.toFixed(1) + ' °C'); setState(idTemp2, Temp2.toFixed(1) + ' °C'); } JSONtoTemp(getState(idJSON).val); // Script start on(idJSON, function(dp) { // triggern bei Wertänderung JSONtoTemp(dp.state.val); });
-
@paul53
Vielen Herzlichen Dank
Läuft wieder, hat sich mal wieder was geändert.
Und sorry, für die späte Rückmeldung.