NEWS
JSON in Objekt/Datenpunkt umwandeln
-
passt nun, auch an dich danke "!!
-
Guten Abend,
ich lese über eine URL das JSON aus und schreibe es in einen Datenpunkt (Daten). Nun will ich den Wert "level" in einen weiteren Datenpunkt schreiben. Das funktioniert aber leider nicht.
Was kurios ist... den Wert "voltage" beispielsweise wird in einen Datenpunkt geschrieben. Was mache ich falsch?Hier mein Blockly:
Hier ein Teil des Inhaltes vom Datenpunkt:
Hier das Resultat in den Datenpunkten:
Der Datenpunkt "Akku" ist richtig.
Der Datenpunkt "Akku_Stand" nicht.Ich habe keine Ahnung woran das liegt. Habt Ihr eine Idee?
Viele Grüße
Matze -
Was mir eben aufgefallen ist:
Battery enthält zwei werte in geschweiften Klammern.
Energy enthält einen Wert in eckigen klammern, der wiederum 8 einzelne Werte in geschweiften Klammern enthält. Deswegen klappt das mit der gleichen Schreibweise nicht, wie bei Voltage.
Mit welcher Schreibweise komme ich an den Wert unter level? -
@matze1909 sagt: Mit welcher Schreibweise komme ich an den Wert unter level?
energy.0.level, denn
energy
enthält ein Array.
Man kann einen Datenpunkt nach dem Schreiben nicht gleich wieder auslesen (asynchrone Ausführung). Nimm deshalb die Variableresult
. -
Ich habe es hinbekommen.
Zu erst das was unter energy steht in einen separaten Datenpunkt und dann mit der Liste arbeiten:
-
@matze1909
Man könnte auch lediglich das JSON in einen DP schreiben und dann mit Aliasen die einzelnen Werte rauspflücken. -
@paul53 vielen Dank...deinen Beitrag hatte ich im ganzen "machen" inhaltlich völlig überlesen. So ist es ja noch viel einfacher.
Danke und einen schönen Abend
Matze -
@matze1909 sagte in JSON in Objekt/Datenpunkt umwandeln:
Danke...ich benötige die Daten aber als Datenpunkt. Wenn ich dich richtig verstanden habe, habe ich dann keine Datenpunkte, oder?
Doch.
Aliase werden im Objektbaum unterhalb vonalias.0
angelegt.
Der Alias „guckt“ auf den DP mit dem JSON.
Über die Konvertierungsfunktion kann man dann einzelne Werte aus dem JSON holen.JSON.parse(val).battery.voltage
-
Ich schaue mir das mit den Aliasen mal an.
Aber noch eine Frage. In meinem Log steht:
request blockly block is deprecated - please use "http get" insteadDie request Funktion ist also veraltet und mal sollte stattdessen die http get Funktion nehmen. Aber wie kann ich dann hierüber einen Datenpunkt oder eine variable mit den JSON Daten aus der url füllen?
Nutze ich die http get Funktion, bleibt bei mir die result Variable bzw. der Datenpunkt leer.Mein Script sieht jetzt so aus:
Was müsste ich verändern?
-
@matze1909 sagte: Was müsste ich verändern?
Es gibt unter "Aktionen" die Variable
data
(anstelle vonresult
). -
@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?