Ich versuche, eine JSON-Zeichenfolge zu seiner niedrigsten Granularität zu einem Panda-Datenfeld zu analysieren.Nested JSON in Datenframe analysieren
Versuche
Zuerst versuchte ich read_json:
jsonData = pd.read_json(apiRequest)
Aber ein großer Teil der Daten wird immer noch unter networkRank verschachtelt.
Dann habe ich versucht json_normalize, aber dieses Mal fehlen mir die Daten eine Ebene höher wie Breite und Länge.
result = json_normalize(json_data['networkRank'])
Ich habe auch "in" die verschachtelte Struktur zu analysieren und den Datenrahmen von Grund auf neu aufzubauen, aber dieses Codes führt zu Fehler:
result_nested = json_normalize(json_data, 'networkRank', ['longitude', 'latitude', ['networkRank', 'type3G', 'downloadSpeed']])
Tor
Analysieren der JSON-Daten in eine flache Tabelle mit allen Feldern, dh Breiten-, Längen- und Entfernungsdaten, die an jede Datenzeile in Abbildungangehängt werden.
JSON String
{'apiVersion': '2',
'distance': 10,
'latitude': '-6.162959',
'longitude': '35.751607',
'networkRank': [{'networkId': '6402',
'networkName': 'Vodacom',
'type3G': {'averageRssiAsu': '9.5429091136',
'averageRssiDb': '-69.5664329624972',
'downloadSpeed': '1508.1304',
'networkId': '6402',
'networkName': 'Vodacom',
'networkType': '3',
'pingTime': '320.9600',
'reliability': '0.804236452826138',
'sampleSizeRSSI': '948',
'sampleSizeSpeed': '29',
'uploadSpeed': '893.7692'}},
{'networkId': '6400',
'networkName': 'tiGO',
'type3G': {'averageRssiAsu': '15.3537142857',
'averageRssiDb': '-61.4563389583101',
'downloadSpeed': '516.0000',
'networkId': '6400',
'networkName': 'tiGO',
'networkType': '3',
'pingTime': '259.0000',
'reliability': '0.911904765537807',
'sampleSizeRSSI': '935',
'sampleSizeSpeed': '21',
'uploadSpeed': '320.4211'}},
{'networkId': '6403',
'networkName': 'Airtel',
'type3G': {'averageRssiAsu': '13.2729999375',
'averageRssiDb': '-58.1521092977699',
'downloadSpeed': '1080.2500',
'networkId': '6403',
'networkName': 'Airtel',
'networkType': '3',
'pingTime': '194.5556',
'reliability': '0.554680264185345',
'sampleSizeRSSI': '587',
'sampleSizeSpeed': '21',
'uploadSpeed': '572.1579'}}],
'network_type': None,
'perMinuteCurrent': 0,
'perMinuteLimit': 10,
'perMonthCurrent': 0,
'perMonthLimit': 2000}