JSON文字列を、パンダのデータフレームに対して最も細かく解析しようとしています。ネストされたJSONをデータフレームに解析する
試み
は、最初に私が試したread_json:jsonData = pd.read_json(apiRequest)
をしかし、大量のデータチャンクはまだnetworkRankの下にネストされています。
次にjson_normalizeを試しましたが、今回は緯度と経度のように1レベル高いデータがありません。
result = json_normalize(json_data['networkRank'])
Iはまた、ネストされた構造 "に" 解析して最初からデータフレームを構築しようとしたが、エラーでこのコードの結果:
result_nested = json_normalize(json_data, 'networkRank', ['longitude', 'latitude', ['networkRank', 'type3G', 'downloadSpeed']])
目標
すべてのフィールドを持つフラットな表にJSONデータを解析するには、図の各データ行に緯度、経度、距離のデータを追加します。2。
JSON文字列
{'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}