NEWS
JSON mit Blockly erstellen
-
Hallo zusammen,
ich möchte mit einer Abfrage ein JSON erstellen und in einen Datenpunkt schreiben.
Die Änderung der Datenpunkte bekomme ich auch schon hin.
Aber wie kann ich den Text sauber umschreiben? Bei mir kommen die Daten nicht sauber rein?!?
["Monat: 2021.12.Anzahl,Anzahl: 0","Monat: 2021.11.Anzahl,Anzahl: 0","Monat: 2021.10.Anzahl,Anzahl: 0","Monat: 2021.09.Anzahl,Anzahl: 0","Monat: 2021.08.Anzahl,Anzahl: 0","Monat: 2021.07.Anzahl,Anzahl: 0","Monat: 2021.06.Anzahl,Anzahl: 0","Monat: 2021.05.Anzahl,Anzahl: 0","Monat: 2021.04.Anzahl,Anzahl: 12","Monat: 2021.03.Anzahl,Anzahl: 12","Monat: 2021.02.Anzahl,Anzahl: 17","Monat: 2021.01.Anzahl,Anzahl: 22"]
-
Bin das Problem anders angegangen, habe es aber noch nicht ganz lösen können.
Ich bekomme jetzt Werte, aber leider "kreuz und quer". Wie kann ich die Werte nach dem Namen der Objekt ID sortieren?
-
ich mache das so - mit hilfe einer kleinen js-function - weiß nicht, ob es eine reine blockly lösung gibt
das ergebnis:
import:
-
@liv-in-sky
und wie bekomme ich da meine Werte in eine Liste?
Stehe gerade auf dem Schlauch bzw bin da nicht ganz so firm drin -
es wird eine leere list erzeugt (mit blockly) - das ist ein array. dann wird in der schleife jeweils ein json in das array "gepusht" (Liste.push(...) ) -( im function-teil)
das ganze ist dann ein sog. json-array - zb. zur anzeige mit inventwo-json widget, ...
die Liste, Array ist [ ]
ein json ist dann: {"name":"KingArtTouchT2 POWER","id":""}am ende hast du dann ein object (json-array) mit lauter json's drin
-
@liv-in-sky und wo gibt es diesen
push
befehl in Blockly? -
dann müssen aber umständich die { und die anführungszeichen eingearbeitetet werden im text bereich (grün)
-
@liv-in-sky sagte in JSON mit Blockly erstellen:
müssen aber umständich die { und die anführungszeichen eingearbeitetet werden im text bereich (grün)
ist kein Problem, wenn es klappt.
Hatte ich auch schon versucht, nur was kommt da in das leere "Loch"
-
@liv-in-sky sagte: in der schleife jeweils ein json in das array "gepusht"
Das ist kein Json, sondern ein Objekt.
Erst JSON.stringify() macht aus dem Array ein Json.@homoran sagte in JSON mit Blockly erstellen:
wo gibt es diesen push befehl in Blockly?
-
@homoran siehe hier
https://forum.iobroker.net/post/588743
endlich ist @paul53 mit dabei - der kennt sich da besser aus
-
@paul53 sagte in JSON mit Blockly erstellen:
Erst JSON.stringify() macht aus dem Array ein Json.
damit Quäle ich mich schon seit Stunden, kommt alles andere als ein echtes JSON bei raus.
Das muss aber noch warten, bis die Struktur steht -
@liv-in-sky sagte: endlich ist @paul53 mit dabei
Ich habe mich bisher zurück gehalten, da uns @jerzimeik bisher nicht verraten hat, wozu er das Json braucht und wie es aussehen soll. Auch über die Datenpunkte, die eingelesen werden, lässt er uns im unklaren.
-
@paul53 sagte:
Erst JSON.stringify() macht aus dem Array ein Json.
und wenn in dem Array ein (oder mehrere) JSON sein soll?
-
@homoran
Ich löse mal aufIch habe Datenobjekte für einen Wert Januar bis Dezember. Diese Werte möchte ich bei Änderung auslesen und in ein Array packen, damit ich danach z.B. einen Chart (Materialdesignwidget) "füllen" kann.
Nachher sollen dann tatsächlich noch weitere Werte wie Kilometer und Stunden in den (oder das) array mit rein. Aber ich wollte ja langsam anfangen und die Systematik erstmal verstehen.
-
@jerzimeik sagte in JSON mit Blockly erstellen:
Ich löse mal auf
so in der Art will ich auch etwas generieren um es anschließend als Tabelle im JSON-Widget darstellen zu können.
Bei mir kommt ohne die manuelle Funktion aber nicht das gewünschte raus:
Weitere Datenreihen sollen noch folgen
-
@homoran sagte: wenn in dem Array ein (oder mehrere) JSON sein soll?
Das macht man nicht, sondern man erstellt ein Array of objects . JSON.stringify(array) macht aus dem ganzen Array ein JSON.
-
@paul53 sagte:
sondern man erstellt ein Array of objects
das muss jetzt erst mal sacken!
aber wenn ich dich schon mal dran hab
Anführungsstreichen wurden escaped. Wann und ob man einfache Anführungszeichen nehmen darf/muss hab ich auch noch nicht verstanden
-
@jerzimeik sagte: Ich habe Datenobjekte für einen Wert Januar bis Dezember.
Hättest Du in der Datenpunkt-ID eine führende 0 für Januar bis September verwendet, würde der Selektor schon richtig sortieren.
Da man mit Blockly keine Objekte erzeugen kann, benötigt man dafür eine JS-Funktion mit Ergebnis. Inhalt der Funktion monat_anzahl(id):
return {Monat: getObject(id).common.name.substring(0, 7), Anzahl: getState(id).val};
Der Datenpunkt ist für die JSON-Tabelle in Vis geeignet (Überschriften: Monat, Anzahl).
-
@paul53 sagte:
Da man mit Blockly keine Objekte erzeugen kann,
in Verbindung mit
@paul53 sagte in JSON mit Blockly erstellen:
man erstellt ein Array of objects
heisst also dass das auch nur über eine js-Funktion geht?
-
@homoran sagte: heisst also dass das auch nur über eine js-Funktion geht?
Ja.