NEWS
Brauche Hilfe um ein json abzurufen und auszuwerten
-
@Homoran Ansatz, um das Array in einer Variablen zu erzeugen. Die Bezeichnung der Variablen result ist vorgegeben.
-
@paul53 sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:
Ansatz, um das Array in einer Variablen zu erzeugen.
Super heißen Dank!
Da war ich schon fast.
kannst du mir bitte noch erklären wie und wohin die "mit Ergebnissen" hinfließen und wie man da wieder ran kommt.
Das war nämlich mein Denk-Knoten. -
@Homoran sagte:
wohin die "mit Ergebnissen" hinfließen und wie man da wieder ran kommt.
Die Ergebnisse werden an die Callback-Funktion (das Maul) in den Variablen error, response und result übergeben. Das JSON wird in result übergeben.
-
@paul53 sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:
in den Variablen error, response und result übergeben
und das muss man wissen
die so bezeichneten Variablen liegen nicht irgendwo als pulldown vor?Dann habe ich es schon richtig geahnt, nur verzweifelt den passende Block gesucht
Das Result ist
[{'hex':'89644e','flight':'UAE184 ','alt_baro':34975,'alt_geom':35475,'gs':517.7,'ias':281,'tas':474,'mach':0.824,'track':99.9,'roll':0,'mag_heading':95.6,'baro_rate':576,'geom_rate':512,'squawk':'0112','category':'A5','nav_qnh':1012.8,'nav_altitude_mcp':35008,'lat':50.293259,'lon':6.842459,'nic':8,'rc':186,'seen_pos':2.6,'version':0,'nic_baro':1,'nac_p':8,'nac_v':1,'sil':2,'sil_type':'unknown','mlat':[],'tisb':[],'messages':148,'seen':2.6,'rssi':-22.8},{'hex':'3d1bb0','mlat':[],'tisb':[],'messages':131,'seen':133,'rssi':-22.2},{'hex':'407510','flight':'WUK1329 ','alt_baro':35025,'alt_geom':35475,'gs':489.5,'ias':265,'tas':446,'mach':0.78,'track':121.1,'track_rate':0.06,'roll':1.2,'mag_heading':117.4,'baro_rate':-128,'geom_rate':-128,'squawk':'2273','emergency':'none','category':'A3','nav_qnh':1012.8,'nav_altitude_mcp':35008,'lat':50.667409,'lon':7.959669,'nic':7,'rc':371,'seen_pos':22.6,'version':2,'nic_baro':1,'nac_p':8,'nac_v':1,'sil':3,'sil_type':'perhour','gva':1,'sda':3,'mlat':[],'tisb':[],'messages':2810,'seen':20.8,'rssi':-22.3},{'hex':'3c4583','flight':'BOX462 ','alt_baro':28000,'alt_geom':28425,'gs':486.4,'ias':335,'tas':500,'mach':0.844,'track':317.9,'roll':0,'mag_heading':314.8,'baro_rate':64,'geom_rate':32,'squawk':'0637','emergency':'none','category':'A5','nav_qnh':1012.8,'nav_altitude_mcp':28000,'nav_heading':315,'lat':50.970016,'lon':6.930814,'nic':8,'rc':186,'seen_pos':7.6,'version':2,'nic_baro':1,'nac_p':9,'nac_v':1,'sil':3,'sil_type':'perhour','gva':2,'sda':2,'mlat':[],'tisb':[],'messages':2000,'seen':1.8,'rssi':-21.1},{'hex':'3c5ee4','category':'A3','version':1,'sil_type':'unknown','mlat':[],'tisb':[],'messages':377,'seen':292.2,'rssi':-22.4},{'hex':'484cb6','alt_baro':39000,'alt_geom':39250,'gs':449.9,'ias':228,'tas':418,'mach':0.74,'track':145.8,'track_rate':0,'roll':0.4,'mag_heading':147.3,'baro_rate':32,'geom_rate':0,'squawk':'0157','category':'A0','lat':50.253296,'lon':7.449526,'nic':8,'rc':186,'seen_pos':52.7,'version':0,'nac_p':8,'nac_v':0,'sil':2,'sil_type':'unknown','mlat':[],'tisb':[],'messages':6980,'seen':31.9,'rssi':-24.2},{'hex':'471f5a','category':'A3','version':2,'sil_type':'perhour','mlat':[],'tisb':[],'messages':664,'seen':248.9,'rssi':-23},{'hex':'484acc','category':'A3','version':2,'sil_type':'perhour','mlat':[],'tisb':[],'messages':4599,'seen':170.9,'rssi':-24.4}]
und den muss ich jetzt splitten -
Danke erst einmal
-
@Homoran sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:
und den muss ich jetzt splitten -
da empfehle ich jsonata, geiles Tool und gibt es auch im Blockly hier mal ein paar Daten
Jsonata Ausdruck:aircraft[flight.$contains(/./)].{ "flight":flight, "lat":lat, "lon":lon, "alt_baro":alt_baro }
Blockly
Gefilterte Daten
[{'flight':'ABR1540 ','alt_baro':34075},{'flight':'EWG53N ','lat':51.072507,'lon':6.167068,'alt_baro':18725},{'flight':'KLM1631 ','lat':50.771453,'lon':6.746521,'alt_baro':41000},{'flight':'EJU93MQ ','lat':50.905655,'lon':7.16509,'alt_baro':38000},{'flight':'KLM73C ','lat':50.463464,'lon':7.402261,'alt_baro':23600},{'flight':'UAL2777 ','lat':50.999313,'lon':6.929255,'alt_baro':29825}]
Spielen mit den Ausdrücken auf https://try.jsonata.org/
-
@fastfoot sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:
da empfehle ich jsonata, geiles Tool
janz langsam mit den alten Pferden
ich will das ganze ja auch verstehen.Bin ja schon ganz stolz, dass ich das json(-Array) iteriert bekommen habe.
Habe dann mal zur Übung die Flugnummer genommenDa ich aber nicht von allen Flugzeugen immer alle Daten reinbekomme muss ich jetzt die
undefined
abfangen.
Das Ganze ist für mich auch eine Übung mich immer tiefer in js einzuarbeitenOptimierungen, wie @paul53 sie bis in den Exzess treibt kommen erst vieeeeeel später
-
@Homoran sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:
Da ich aber nicht von allen Flugzeugen immer alle Daten reinbekomme muss ich jetzt die undefined abfangen.
Das Ganze ist für mich auch eine Übung mich immer tiefer in js einzuarbeitenDu kannst ja auch über die gefilterten Daten iterieren, letztendlich ist das Ergebnis auch 'nur' ein JSON. Arbeit haste da noch genug, ist aber einfacher, gerade als Anfänger
-
@fastfoot sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:
Arbeit haste da noch genug,
das stimmt.
Wollte jetzt Höhe, lat und long auskesen.
Dann kommt noch Pythagoras in der Ebene zu meinem Wohnort und vor dem Pythagoras im dreidimensionalen Raum (Entfernung Flugzeug zum Haus) graut mir auch schon.Dann wollte ich das Ergebnis jeweils in ein weiteres Json abspeichern, wenn der Flieger am dichtesten bei mir ist und diese Liste dann in vis darstellen.
Das ist für mich ein Jahresprogramm
Aber ich bilde mir ein, man lernt am besten wenn man weiß was man will und ein Ziel hatEDIT:
Habe mir dein Blockly jetzt doch näher angesehen, war einfach zu neugierig.
Mit dem JSONata kann man das UrsprungsJSON also filtern und dann nur noch mit den Datensätzen, die für mich relevant wären weiterarbeiten? -
@Homoran sagte:
muss ich jetzt die undefined abfangen.
-
@paul53 ich habe wieder zu komliziert (nämlich umgekehrt) gedacht und mit
Falls nicht undefined
versucht -
@Homoran sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:
Mit dem JSONata kann man das UrsprungsJSON also filtern und dann nur noch mit den Datensätzen, die für mich relevant wären weiterarbeiten?
Genau, habe den Ausdruck extra formatiert, einfach die Daten, welche du brauchst anhängen und dann hast du nur die Daten welche du brauchst, lan, lon und Höhe sind ja schon drin.. Den Rest machst du wie von Paul gezeigt
-
-
@Homoran sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:
das muss ich jetzt erst einmal verdauen
vor einer Woche konnte ich jsonata gerade mal buchstabieren, jetzt gehts schon recht flott Genau so wird es dir auch gehen mit deinem Projekt. Viel Erfolg.
PS: Die Daten die du ziehst sind kostenpflichtig?
-
@fastfoot sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:
Die Daten die du ziehst sind kostenpflichtig?
Nö, ich fange sie mit einem DVB-T Receiver an einem RasPi selber ab
-
@fastfoot sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:
Spielen mit den Ausdrücken auf https://try.jsonata.org/
Habe ich jetzt ein wenig gemacht.
Das erträumte Ergebnis war ernüchterndHabe dann sogar das Unmögliche getan und die Doku gelesen. Aber auch dort keinen korrekten Hinweis auf meinen Wunsch erhalten:
kann man in dem
expression
bereits z.B. (Wohnort - x) < lat > (Wohnort +x) filtern?
Habe dazu nichts gefunden, resp. bekam nur ERROR -
@Homoran sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:
kann man in dem expression bereits z.B. (Wohnort - x) < lat > (Wohnort +x) filtern?
Habe dazu nichts gefunden, resp. bekam nur ERRORDu kannst im Filter(alles zwischen den eckigen Klammern) folgendes eingeben
aircraft[lat >50 and lat < 52].{ "flight":flight, "lat":lat, "lon":lon, "alt_baro":alt_baro }
probiere das mal mit fixen Werten zuerst, später kannst du ja Variablen einfügen. Hier habe ich den Filter für die Flugnummer entfernt, weil ich denke dass lat und lon eh nur da sind wenn eine Flugnummer existiert. denke daran dass du einen Punkt statt Komma in der Angabe benutzt, also zB lat > 50.0400776
-
@fastfoot werde ich testen - danke!
@fastfoot sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:
probiere das mal mit fixen Werten zuerst, später kannst du ja Variablen einfügen.
genau das hatte ich vor, zumal ich nicht weiß wie ich an die Geokoordinaten aus der Systemsteuerung komme
@fastfoot sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:
dass lat und lon eh nur da sind wenn eine Flugnummer existiert.
nicht mal dann.
Wenn der Empfang schlecht ist heisst es:Total Aircraft: 7 With Positions: 4
Die 7 haben ihr Kennzeichen aber nicht alle eine aktuelle Position.
Die Daten werden jede Sekunde aktualisiert -
@Homoran solange du noch entwickelst, würde ich die Aktualisierungsrate nicht so niedrig setzen, damit du nicht durcheinander kommst. der letzte Filter bringt nur Daten wenn Positionsdaten da sind, könntest auch noch die Höhe einbeziehen. Ich würde mir ein JSON in eine Variable schreiben und mit diesen Daten hantieren bis das Ergebnis stimmt, dann erst würde ich live Daten auf mein Programm loslassen
-
@fastfoot
Habe jetzt dem JSONata noch die maximale Höhe mitgegeben da laufe ich in das nächste für mich nicht nachvollziehbare Problem:
es kommt wieder undefined17:07:00.047 info javascript.0 (13728) script.js.Fliegenklatsche: undefined 17:07:15.012 info javascript.0 (13728) script.js.Fliegenklatsche: undefined
das json ist im Moment leer
Außerdem erscheint immer mal wieder ein parser Error (IMHO vom debug), den ich auch nicht verstehe
-
@fastfoot sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:
würde ich die Aktualisierungsrate nicht so niedrig setzen
damit meinte ich die Aktualisierung des jsons auf dem RasPi
sobald dort 1 Sekunde keine Daten vom Flieger empfangen werden zählt ein Zähler hoch und nach 60 Sekunden ist er aus der Liste raus, vorher ggf. schcon die Positionsdaten.ich habe den Trigger abgeschaltet und rufe das json manuell auf
Aber ich muss es ja auch im real-Life Betrieb testen - siehe letzter post