NEWS
JSON in Objekt/Datenpunkt umwandeln
-
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. -
@paul53 sagte in JSON in Objekt/Datenpunkt umwandeln:
Außerdem kann man unmittelbar nach dem Schreiben in einen DP ihn nicht gleich wieder einlesen, da "aktualisiere" asynchron ausgeführt wird.
Ahh das wusste ich noch nicht.
Bei mir sieht es jetzt so aus:
Ich bekomme aber als Ausgabe:
"{\"value\":22.5}"
Also die Spiegelstriche sind überflüssig. Wo kommen die her?
Danke für die Hilfe!
@Codierknecht Danke! Mit Debug Info geht es schneller Ausgabe dazu siehe oben.
-
@dan11hh sagte in JSON in Objekt/Datenpunkt umwandeln:
Also die Spiegelstriche sind überflüssig. Wo kommen die her?
Naja, die sind in diesem Fall nicht überflüssig weil die ganze Ausgabe ja selbst in
"
steht. Dann müssen die inneren "Escaped" werden, das macht man mit Spiegelstrichen.Beides ist also richtig:
"{\"value\":22.5}" {"value":22.5}
Ist das die Debug Ausgabe? Dann könnte das beim Umwandeln in einen String passieren
-
@dan11hh
Bau Dir für die Ausgabe ein neues Objekt - so wie in meinem Beispiel.
Du konvertierst da auch viel zu oft hin und her und liest weiterhin einen Wert, den Du gerade erst geschrieben hat.Versuch's mal auf die Art:
Wenn's nicht funktioniert, poste mal hier das JSON aus dem Trigger, damit wir das nachstellen und testen können.
-
@dan11hh sagte: Bei mir sieht es jetzt so aus:
Sehr chaotisch.
Soll der Wert von "value" nur aufgerundet in den MinimalenEntladeSoC geschrieben werden?EDIT: Mit sinnvollen Variablenbezeichnern macht man sich das Leben einfacher.
-
@paul53
Eigentlich will ich etwas ganz einfachers:Ich möchte, ausgelöst durch den Trigger "Sofort Laden", dass der AktuelleBatterieSOC den MinimalenEntladeSoC überschreibt.
Das war es eigentlich schon. Wären die Werte nicht alle als JSON abgespeichert, hätte ich das schon hinbekommen. Aber so
Hintergrund ist, dass ich, wenn die Wallbox auf Sofort-Laden geht, der Hausspeicher nicht entladen wird, sondern nur aus dem Netz gezogen wird.
Das Erkennen des "Sofort-Ladens" klappt ja auch schon. Nur das schreiben des AktuellenSoC in den MinimalenEntladeSoC nicht.
Ich probiere jetzt mal deinen EDIT aus.
EDIT:
Ja, jetzt klappt es. 1000DANK! Ich arbeite fast nie mit Variable, deshalb habe ich, glaube ich, den ersten Versuch vermurkst. Will ich mir gleich nochmal angucken.