Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. Brauche Hilfe um ein json abzurufen und auszuwerten

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Brauche Hilfe um ein json abzurufen und auszuwerten

    This topic has been deleted. Only users with topic management privileges can see it.
    • paul53
      paul53 @Homoran last edited by

      @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.

      Homoran 1 Reply Last reply Reply Quote 1
      • Homoran
        Homoran Global Moderator Administrators @paul53 last edited by Homoran

        @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 -

        json_split.png

        Danke erst einmal

        F 1 Reply Last reply Reply Quote 0
        • F
          fastfoot @Homoran last edited by fastfoot

          @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
          flight2.PNG

          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/

          Homoran 2 Replies Last reply Reply Quote 0
          • Homoran
            Homoran Global Moderator Administrators @fastfoot last edited by Homoran

            @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 genommen

            Flugnummern.png

            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 einzuarbeiten

            Optimierungen, wie @paul53 sie bis in den Exzess treibt kommen erst vieeeeeel später

            F paul53 2 Replies Last reply Reply Quote 0
            • F
              fastfoot @Homoran last edited by

              @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 einzuarbeiten

              Du 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

              Homoran 1 Reply Last reply Reply Quote 0
              • Homoran
                Homoran Global Moderator Administrators @fastfoot last edited by Homoran

                @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 hat

                EDIT:
                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?

                F 1 Reply Last reply Reply Quote 0
                • paul53
                  paul53 @Homoran last edited by paul53

                  @Homoran sagte:

                  muss ich jetzt die undefined abfangen.

                  Blockly_temp.JPG

                  Homoran 1 Reply Last reply Reply Quote 1
                  • Homoran
                    Homoran Global Moderator Administrators @paul53 last edited by

                    @paul53 ich habe wieder zu komliziert (nämlich umgekehrt) gedacht und mit Falls nicht undefined versucht

                    1 Reply Last reply Reply Quote 0
                    • F
                      fastfoot @Homoran last edited by

                      @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

                      1 Reply Last reply Reply Quote 1
                      • Homoran
                        Homoran Global Moderator Administrators last edited by

                        @fastfoot
                        @paul53

                        DANKE!

                        das muss ich jetzt erst einmal verdauen

                        F 1 Reply Last reply Reply Quote 0
                        • F
                          fastfoot @Homoran last edited by

                          @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?

                          Homoran 1 Reply Last reply Reply Quote 0
                          • Homoran
                            Homoran Global Moderator Administrators @fastfoot last edited by Homoran

                            @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

                            1 Reply Last reply Reply Quote 1
                            • Homoran
                              Homoran Global Moderator Administrators @fastfoot last edited by

                              @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üchternd 😉

                              Habe 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

                              F 1 Reply Last reply Reply Quote 0
                              • F
                                fastfoot @Homoran last edited by

                                @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 ERROR

                                Du 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

                                Homoran 1 Reply Last reply Reply Quote 0
                                • Homoran
                                  Homoran Global Moderator Administrators @fastfoot last edited by

                                  @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

                                  F paul53 2 Replies Last reply Reply Quote 0
                                  • F
                                    fastfoot @Homoran last edited by

                                    @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

                                    Homoran 1 Reply Last reply Reply Quote 0
                                    • Homoran
                                      Homoran Global Moderator Administrators last edited by

                                      @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 undefined 😞

                                      17: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

                                      parser_error.png

                                      F 1 Reply Last reply Reply Quote 0
                                      • Homoran
                                        Homoran Global Moderator Administrators @fastfoot last edited by

                                        @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 😉

                                        1 Reply Last reply Reply Quote 0
                                        • F
                                          fastfoot @Homoran last edited by fastfoot

                                          @Homoran Du musst das Ergebnis prüfen: Falls erg dann action. Wenn keine Daten da sind ist das Ergebnis undefined. Den Filter nicht zu eng setzen, während der Entwicklung!
                                          flight3.PNG

                                          Homoran 1 Reply Last reply Reply Quote 0
                                          • Homoran
                                            Homoran Global Moderator Administrators @fastfoot last edited by Homoran

                                            @fastfoot sagte in Brauche Hilfe um ein json abzurufen und auszuwerten:

                                            Falls erg dann action

                                            Jepp, danke

                                            Bin ja schon am finetuning der Rohdaten 😉
                                            ich ändere immer wieder den Range um nichts leeres zu bekommen. Aber auch das muss ich abfangen.

                                            Aus dem Parser Error werde ich nicht schlau. Hier mal alle Daten, vielleicht etwas unübersichtlich:
                                            HUMMEL4_parser.png

                                            Der Schraubenhuber flog eben direkt über unser Haus 😉
                                            Screen der Karte, der Live-Daten und des js-logs

                                            Hier das zeitgleiche json

                                            { "now" : 1603552640.8,
                                              "messages" : 1850340,
                                              "aircraft" : [
                                                {"hex":"3df744","flight":"HUMMEL4 ","alt_baro":800,"alt_geom":900,"gs":133.7,"track":332.9,"baro_rate":-128,"squawk":"4426","emergency":"none","category":"A7","lat":50.900574,"lon":6.983445,"nic":9,"rc":75,"seen_pos":0.1,"version":2,"nic_baro":1,"nac_p":10,"nac_v":2,"sil":3,"sil_type":"perhour","gva":2,"sda":2,"mlat":[],"tisb":[],"messages":453,"seen":0.1,"rssi":-16.2},
                                                {"hex":"3c66ea","flight":"DLH3U   ","alt_baro":21875,"alt_geom":22450,"gs":402.4,"ias":271,"tas":376,"mach":0.612,"track":94.7,"track_rate":0.00,"roll":-0.2,"mag_heading":94.6,"baro_rate":-1856,"geom_rate":-1856,"squawk":"5245","emergency":"none","category":"A3","nav_qnh":1012.8,"nav_altitude_mcp":11008,"lat":50.328555,"lon":7.004230,"nic":8,"rc":186,"seen_pos":14.4,"version":2,"nic_baro":1,"nac_p":9,"nac_v":1,"sil":3,"sil_type":"perhour","gva":2,"sda":2,"mlat":[],"tisb":[],"messages":351,"seen":12.8,"rssi":-22.1},
                                                {"hex":"461e16","flight":"FIN3EF  ","alt_baro":40000,"alt_geom":40350,"gs":409.6,"ias":233,"tas":432,"mach":0.772,"track":226.7,"track_rate":0.00,"roll":0.0,"mag_heading":229.6,"baro_rate":64,"geom_rate":32,"squawk":"1000","category":"A3","nav_qnh":1013.6,"nav_altitude_mcp":40000,"nav_altitude_fms":40000,"nav_modes":["autopilot","vnav","tcas"],"lat":50.716599,"lon":7.030730,"nic":8,"rc":186,"seen_pos":2.0,"version":2,"nic_baro":1,"nac_p":10,"nac_v":2,"sil":3,"sil_type":"perhour","gva":2,"sda":2,"mlat":[],"tisb":[],"messages":2888,"seen":1.5,"rssi":-19.9},
                                                {"hex":"4400d0","alt_baro":21825,"alt_geom":22300,"gs":401.2,"ias":284,"mach":0.632,"track":116.5,"mag_heading":104.2,"baro_rate":1984,"geom_rate":1984,"squawk":"5333","version":2,"nac_v":2,"sil_type":"perhour","mlat":[],"tisb":[],"messages":74,"seen":19.3,"rssi":-22.4},
                                                {"hex":"ac45d5","alt_baro":14950,"alt_geom":15250,"gs":362.1,"ias":313,"tas":392,"mach":0.620,"track":238.0,"roll":-0.4,"mag_heading":235.7,"baro_rate":-2624,"geom_rate":-3072,"squawk":"7702","category":"A5","nav_qnh":1012.8,"nav_altitude_mcp":11008,"nav_heading":237.7,"lat":50.936016,"lon":6.497955,"nic":8,"rc":186,"seen_pos":48.4,"version":2,"nic_baro":1,"nac_p":9,"nac_v":1,"sil":3,"sil_type":"perhour","gva":2,"sda":2,"mlat":[],"tisb":[],"messages":711,"seen":42.3,"rssi":-21.2},
                                                {"hex":"406a59","version":0,"sil_type":"unknown","mlat":[],"tisb":[],"messages":45,"seen":221.6,"rssi":-23.3},
                                                {"hex":"4072c8","category":"A3","version":2,"sil_type":"perhour","mlat":[],"tisb":[],"messages":3337,"seen":71.3,"rssi":-22.5},
                                                {"hex":"407797","flight":"EZY21DC ","alt_baro":38000,"alt_geom":38400,"gs":381.5,"ias":244,"tas":434,"mach":0.772,"track":289.8,"track_rate":0.03,"roll":-0.4,"mag_heading":286.2,"baro_rate":0,"geom_rate":-32,"squawk":"6604","category":"A3","nav_qnh":1013.6,"nav_altitude_mcp":38016,"nav_heading":0.0,"lat":51.126088,"lon":6.040497,"nic":8,"rc":186,"seen_pos":0.2,"version":2,"nic_baro":1,"nac_p":9,"nac_v":1,"sil":3,"sil_type":"perhour","mlat":[],"tisb":[],"messages":8064,"seen":0.2,"rssi":-20.7}
                                              ]
                                            }
                                            

                                            Warum mag der die Hummel nicht?

                                            F 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            615
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            3
                                            53
                                            2362
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo