NEWS
[gelöst] Blockly JSON Eintrag ändern
-
@rantanplan sagte: Anstatt den Nachnamen zu ändern
-
$~>|Name|{"Nachname":"geänderter Nachname"}|
Hier wieder Dein Blockly zurück mit den Ergänzungen:
Wie gesagt, wahrscheinlich kann das Puzzleteil nicht mit verschachtelten Objekten arbeiten.
Genau- wie @paul53 es sonst letztlich gemacht hat in dem er alles bis auf eine Ebene in ein Objekt gebracht hat. Also
name2:{ Vorname: 'Henri-2', Nachname: 'Mustermann-2' }
Wie gesagt, ich würde bei JSONATA bleiben, wenn Du es beherrschst - dann sparst Du Dir viel Code.
-
@mickym sagte: sparst Du Dir viel Code.
So viel Code ist es auch nicht, wenn man auf Zwischenvariablen verzichtet.
-
@paul53 OK - gebe ich Dir Recht. Allerdings kann man halt mit JSONATA auch das ganze Objekt belassen und die Stelle, die geändert werden muss genau spezifizieren:
$~>|$[id=2].Name|{"Nachname":"geänderter Nachname"}|
https://try.jsonata.org/p84fe2dLO
das finde ich (nur persönliche Meinung) schon genial.
-
@mickym sagt: das finde ich (nur persönliche Meinung) schon genial.
Das ist es, wenn man JSONATA beherrscht.
-
-
@rantanplan Nur der Vollständigkeit halber noch im Blockly mit JSONATA und Änderung des Nachnames der Person mit id=2 unter Beibehaltung des Gesamtobjektes (also Update):
-
@paul53 sagte in Blockly JSON Eintrag ändern:
@mickym sagt: das finde ich (nur persönliche Meinung) schon genial.
Das ist es, wenn man JSONATA beherrscht.
Nochmals herzlichen Dank an @paul53 und @mickym
Ihr habt beide recht und beide Lösungen funktionieren.Der Nachteil bei dem "setze Attribut"-Baustein ist, dass er nicht flexibel ist.
Für jeden zu ändernden Wert müsste ein Baustein erstellt werden.Da ist die Lösung über JSONata besser.
Mal sehen wie ich mit der JSONata-Syntax zurecht komme wenn das JSON anders aussiehtIch habe mal mein Beispiel an JSONata angepasst und eine flexible Syntax angefügt.
Blockly Bild:
Blockly Source:
Damit werde ich mal weitere Versuche anstellen.
Nochmal vielen Dank!
Grüße
-
@rantanplan Na ja ich finde die JSONATA Syntax schon flexibel genug - ausserdem will man ja manchmal was anderes haben. Ich würde lieber mit dem JSONATA Exerciser üben und dann kannst Du diese Ausdrücke sofort hinschreiben und musst nicht erst eine Funktion aufrufen.
-
@mickym sagte in [gelöst] Blockly JSON Eintrag ändern:
@rantanplan Na ja ich finde die JSONATA Syntax schon flexibel genug - ausserdem will man ja manchmal was anderes haben.
Ja, deshalb eine flexible Abfrage.
Ich würde lieber mit dem JSONATA Exerciser üben
Das werde ich bestimmt tun.
und dann kannst Du diese Ausdrücke sofort hinschreiben und musst nicht erst eine Funktion aufrufen.
Aber dann hätte ich ja wieder eine starre Abfrage.
Erst einmal wollte ich die Möglichkeiten von JSON abklopfen und verstehen.
Jetzt überlege ich mir welche meiner Blocklys ich eventuell anpassen könnte.Eventuell probiere ich es bei meiner Heizungssteuerung.
Und da für jeden Raum, Zeiten, Temperaturen usw. feste Ausdrücke zu verwenden finde schier unmöglich.
Oder sehe ich da was falsch?Grüße
-
@rantanplan sagte in [gelöst] Blockly JSON Eintrag ändern:
Eventuell probiere ich es bei meiner Heizungssteuerung.
Und da für jeden Raum, Zeiten, Temperaturen usw. feste Ausdrücke zu verwenden finde schier unmöglich.
Oder sehe ich da was falsch?Na in meinen Augen siehst Du das falsch. Anstelle eine Funktion aufzurufen, kannst du doch den JSONATA Eintrag direkt erstellen. Du kannst den ja auch insgesamt als einen String abspeichern.
Ich seh hinter diesem Funktionsblock keinen Vorteil, ausser dass er Dir am Anfang eine Schablone gibt.Du kannst auch den ganzen Ausdruck in eine Variable setzen:
Wie gesagt, am Anfang hilft Dir das vielleicht - versuch halt lieber die Syntax zu verstehen:
https://docs.jsonata.org/other-operators#-------transformNehmen wir mal an, Du möchtest bei allen Namen noch die Anrede in das Objekt einfügen, dann stimmt doch der Ausdruck schon nicht mehr.
Letztlich lässt Du Dir zwar mit Deiner Funktion nur die Syntax zusammenstellen.
letztlich sind ja Deine Parameter index, key1, key2, value - auch fix - wenn Du diese Funktion aufrufst bzw. wenn Du Dir aus Datenpunkten holst. Aber egal- Du bekommst das schon hin.
Wenn Du Dir die Syntax anschaust, dann siehst Du ja an der Funktionsbeschreibung, die einzelnen Parameter:
head ~> | location | update [, delete] |
head
Mit "head" spezifierst Du das ganze Objekt - welches Du wie auch immer verändert wieder haben willst.
Schau mal das kennst Du ja bereits - als Transformation des gesamten Heads:
Wenn Du als "head" nun nur noch das einzelne Objekt wieder haben willst, mit der id 2 dann filterst Du bereits im head.
Jetzt bekommst Du also nur noch das Objekt zurück, was Du über den head bereits gefiltert hast.
$[id=2]~>|Name|{"Nachname":"geänderter Nachname"}|
Wenn Du im head schon bis zum Namensobjekt gefiltert hast, dann bekommst Du auch nur noch das Namensobjekt zurück. Dann ist der Pfad zum Objekt (location) natürlich das Objekt selbst.
$[id=2].Name~>|$|{"Nachname":"geänderter Nachname"}|
Probiers im Exerciser einfach aus.
location
Das ist der Pfad zu dem Objekt, dass Du modifzieren willst. Der Pfad richtet sich danach, wie der head ausschaut, also ob Du das ganze Ausgangsobjekt nimmst oder nur einen Teil.
update
Da schreibst Du in Objektschreibweise hin, welche Eigenschaft Du ändern willst. Existiert diese nicht wird sie hinzugefügt
======================================================================================
Wenn ich also so eine Funktion basteln würde, dann würde ich das mit diesen 3 Parametern machen .
-
@mickym sagte in [gelöst] Blockly JSON Eintrag ändern:
Na in meinen Augen siehst Du das falsch. Anstelle eine Funktion aufzurufen, kannst du doch den JSONATA Eintrag direkt erstellen.
Jetzt habe ich Dich verstanden. Aber die komplette Syntax zu bauen ist schon die Königsdisziplin.
Ich seh hinter diesem Funktionsblock keinen Vorteil, ausser dass er Dir am Anfang eine Schablone gibt.
Ja, eine Schablone ist aber schon mal ein Anfang. Und weniger Fehleranfällig.
Wie gesagt, am Anfang hilft Dir das vielleicht - versuch halt lieber die Syntax zu verstehen:
Ich werde es versuchen.
letztlich sind ja Deine Parameter index, key1, key2, value - auch fix - wenn Du diese Funktion aufrufst bzw. wenn Du Dir aus Datenpunkten holst.
Ja, aber einem Blockly/JSON angepasst.
Ich muss erstmal anfangen. Vielleicht kommt ja noch ein AHA-Effekt.Aber egal- Du bekommst das schon hin.
Überschätz mich nicht
-
@rantanplan sagte in [gelöst] Blockly JSON Eintrag ändern:
Überschätz mich nicht
Ich muss manchmal auch probieren - es wäre gelogen, wenn ich einfach sagen würde - dass es mir nur so aus den Fingern fließt. Deswegen liebe ich den Exerciser - da ich dann solange rumprobieren kann, bis es passt.
Wenn Du nur einen Parameter ändern willst, passt das ja - aber stell Dir mal vor, Du willst für die Person, Vor- und Nachname ändern?
Wie einfach das im Grunde geht.
$~>|$[id=2].Name|{"Vorname":"Max","Nachname":"Mustermann"}|
Und wie gesagt, scheu Dich halt nicht zu fragen. Für mich war das am Anfang auch schwer zu verstehen - heute bin ich sowas von begeistert. Ich glaube das merkt man auch.