NEWS
JSON in Objekt/Datenpunkt umwandeln
-
@paul53
Hello!Wo genau bekomme ich die Variable "data" her?
Unter Aktionen habe ich keine Möglichkeit es zu nutzen bzw. finde ich es nicht.
Habe auch schon die Variable manuell angelegt aber bei der Ausgabe kommt nur ein undefined.
Hab den JS-Adapter auch schon mal neu gestartet - ohne Erfolg.
Ich finde die Doku sollte bei neuen Funktionen dahingehend auch angepasst werden -> Aktionen
Vielleicht könnte @klein0r (@haus-automatisierung ) das noch anpassenVielen Dank im Voraus!
-
@thomas-schulze sagte: Wo genau bekomme ich die Variable "data" her?
JS-Version 7.11.1:
-
@thomas-schulze sagte in JSON in Objekt/Datenpunkt umwandeln:
Ich finde die Doku sollte bei neuen Funktionen dahingehend auch angepasst werden -> Aktionen
Na dann mal los Dreisprachig alle Screenshots neu zu erstellen ist schonmal ne super Aufgabe... Die könntest Du mir ja abnehmen, oder? Dann passe ich die Texte an.
-
@haus-automatisierung
Denke das bekomm ich hin
Also einfach Screenshots(de, en und ru) von den 9 Blöcken unter Aktionen?
Und wo soll ich die ablegen? In die Cloud oder via E-mail?VG
-
@thomas-schulze Na wenn dann machen wir doch gleich die ganze Doku ordentlich und aktualisieren alle Screenshots, oder?
-
@haus-automatisierung Ui. OK.
Also alle in IoBroker zur Verfügung stehenden Grafikblöcke?
Das wird dann aber frühestens ende nächster Woche was bei mir(2 Kinder + Frau + Haus + was man sonst noch so hat).
Ich schick dir ne PM wenn fertig.VG
-
@thomas-schulze Alle Bilder, welche hier zu finden sind:
https://github.com/ioBroker/ioBroker.javascript/tree/master/docs/en/img
Am einfachsten per Pull Request. Dann steht auch am Ende dein Name dran
-
wie kann ich denn aus dem Tibber JSON den Verbrauch vom aktuellen Tag in einen Datenpunkt, z.b. alias.0.tibber.verbrauch_heute schreiben?
Das geht ja über die Konvertierfunktion, aber da muss ich ja dann noch zusätzlich das Datum mit dem aktuellen vergleichen oder wie lös ich das am besten?[ { "from": "2024-08-25T00:00:00.000+02:00", "to": "2024-08-26T00:00:00.000+02:00", "cost": 0.7771725066, "unitPrice": 0.214985, "unitPriceVAT": 0.034325, "consumption": 3.615, "consumptionUnit": "kWh", "currency": "EUR" }, { "from": "2024-08-26T00:00:00.000+02:00", "to": "2024-08-27T00:00:00.000+02:00", "cost": 1.8533735325, "unitPrice": 0.333161, "unitPriceVAT": 0.053194, "consumption": 5.563, "consumptionUnit": "kWh", "currency": "EUR" }, { "from": "2024-08-27T00:00:00.000+02:00", "to": "2024-08-28T00:00:00.000+02:00", "cost": 1.2193425678, "unitPrice": 0.303018, "unitPriceVAT": 0.048381, "consumption": 4.024, "consumptionUnit": "kWh", "currency": "EUR" }, { "from": "2024-08-28T00:00:00.000+02:00", "to": "2024-08-29T00:00:00.000+02:00", "cost": 0.5764352146, "unitPrice": 0.338085, "unitPriceVAT": 0.05398, "consumption": 1.705, "consumptionUnit": "kWh", "currency": "EUR" }, { "from": "2024-08-29T00:00:00.000+02:00", "to": "2024-08-30T00:00:00.000+02:00", "cost": 0.1608156004, "unitPrice": 0.384726, "unitPriceVAT": 0.061427, "consumption": 0.418, "consumptionUnit": "kWh", "currency": "EUR" }, { "from": "2024-08-30T00:00:00.000+02:00", "to": "2024-08-31T00:00:00.000+02:00", "cost": 0.0520080932, "unitPrice": 0.346721, "unitPriceVAT": 0.055359, "consumption": 0.15, "consumptionUnit": "kWh", "currency": "EUR" }, { "from": "2024-08-31T00:00:00.000+02:00", "to": "2024-09-01T00:00:00.000+02:00", "cost": 0.0644335496, "unitPrice": 0.320565, "unitPriceVAT": 0.051183, "consumption": 0.201, "consumptionUnit": "kWh", "currency": "EUR" } ]
-
@diamand2k22 sagte: das Datum mit dem aktuellen vergleichen oder wie lös ich das am besten?
Steht der Verbrauch des letzten Tages nicht immer an letzter Stelle im Array? Dann ist keine Prüfung des Datums nötig.
Versuche es mal so: -
Danke erstmal für das Blockly!
Würde das auch mit der JASON Parse Funktion mit dem alias converter gehen, dass ich nur den letzten Wert parse? -
@diamand2k22 sagte: mit dem alias converter gehen, dass ich nur den letzten Wert parse?
JSON.parse(val).pop().consumption
-
@paul53 Hilfe! Ich hänge...
Sonst bekomme ich meine Blocklys einigermaßen dazu, was ich machen möchte. Sobald ich aber JSON Werte auslesen möchte, scheitere ich regelmäßig. Das will ich nicht mehr.Hintergrund:
Ich möchte verhindern, dass mein eAuto aus dem Speicher geladen wird. Also erstmal eine Überprüfung ob "Sofort Laden" in der Wallbox (OpenWB) aktiviert ist, dann soll der GridSetPoint des Batteriewechselrichters laufend der aktuellen Ladeleistung des Autos angepasst werden. Alle Werte sind per MQTT vorhanden. Ich scheitere aber schon an dem JSON Wert für den GridPoint. Der wird wie folgt angegeben:{"max":1000000.0,"min":-1000000.0,"value":-10.0}
Ich würde nun gerne die -10 in einen Datenpunkt schreiben. Habe oben mal das Beispiel rudimentär nachgebaut um zu sehen was passiert. Klappt so natürlich nicht.
Was mache ich falsch. Mit Listen habe ich leider auch noch nicht gearbeitet.
-
@dan11hh sagte: -10 in einen Datenpunkt schreiben.
Das ist keine Liste, sondern ein einfaches Objekt.
-
@paul53 So easy!? Danke! Das hilft mir wirklich sehr. Woran erkenne ich ein Objekt? Das nur ein "Value-Wert" enthalten ist? Wie kann ich dann schreiben? Also in das Objekt? Möchte ja die -10 gegen einen anderen Wert austauschen...
-
@dan11hh sagte: Woran erkenne ich ein Objekt?
An den geschweiften Klammern. Eine Liste hat eckige Klammern.
@dan11hh sagte in JSON in Objekt/Datenpunkt umwandeln:
Wie kann ich dann schreiben? Also in das Objekt? Möchte ja die -10 gegen einen anderen Wert austauschen...
Etwa so:
-
@paul53 @paul53
Top. Danke. Das funktioniert!
Es geht leider noch weiter:{"name": "Standard-Lade-Profil", "prio": true, "load_default": false, "et": {"active": true, "max_price": 0.00016}, "time_charging": {"active": false}, "chargemode": {"selected": "instant_charging", "pv_charging": {"min_soc_current": 7, "min_current": 0, "feed_in_limit": false, "min_soc": 20, "max_soc": 100}, "scheduled_charging": {}, "instant_charging": {"current": 32, "limit": {"selected": "none", "amount": 27000, "soc": 100}}}}
Ich möchte überprüfen ob der Wert "instant_charging" ausgewählt ist. Dann brauch ich eine Liste, oder?
So geht es leider nicht:Als Ergebnis hab ich immer 169. Warum auch immer...
-
@dan11hh sagte: Dann brauch ich eine Liste, oder?
Das ist ein strukturiertes Objekt.
@dan11hh sagte in JSON in Objekt/Datenpunkt umwandeln:
ob der Wert "instant_charging" ausgewählt ist.
Attribut: "chargemode.selected"
-
@paul53 Danke DIr. Wieder was gelernt. So langsam verstehe ich, glaube ich, das Prinzip. Danke für die Geduld. Hoffe ich strapaziere diese nicht über, wenn ich nochmal fragen muss:
Mein Skript funktioniert, bis auf die Übergabe als JSON. Also ich bekomme in den letzten Datenpunkt nur den Wert reingeschrieben, also bspw. 50. Ich brauche aber ja: {"value":50} Hast du eine Idee? -
@dan11hh sagte in JSON in Objekt/Datenpunkt umwandeln:
Hast du eine Idee?
-
@dan11hh sagte: Hast du eine Idee?
Das Objekt ist nicht
minSoC
, sondernAktuellerBatterieSoC
. Außerdem kann man unmittelbar nach dem Schreiben in einen DP ihn nicht gleich wieder einlesen, da "aktualisiere" asynchron ausgeführt wird.
Lese "value" in die VariableminSoC
ein und verwende diese weiter.