[英]Python convert JSON to CSV
我有一個 JSON 文件,其中包含:
{
"leaderboard": {
"$": [
{
"userId": 1432024286216,
"userName": "Joe Bloggs",
"score": 111111,
"gameType": "standard",
"dateCreated": 1432024397833,
"_id": 1432024397833
},
{
"userId": 1432024626556,
"userName": "Jane Bloggs",
"score": 222222,
"gameType": "demo",
"dateCreated": 1432024730861,
"_id": 1432024730861
}
]
},
"users": {
"$": [
{
"userId_U": 1432024286000,
"userName_U": "Paul Bloggs",
"score_U": 333333,
"gameType_U": "standard",
"dateCreated_U": 1432024397833,
"_id_U": 1432024397833
},
{
"userId_U": 1432024626777,
"userName_U": "John Bloggs",
"score_U": 444444,
"gameType_U": "demo",
"dateCreated_U": 1432024730861,
"_id_U": 1432024730861
}
]
}
}
我正在嘗試在 Python 中從這里創建一個 CSV。 CSV 僅從“排行榜”數據對象創建標題:userId、userName 等,並為其填充相應的數據。 因此,分別為:userId、userName 等創建一列。
我開始對此進行編碼,但我正在創建“排行榜”和“用戶”標題以及它們下方的一個單元格中的數據。 我的代碼:
import json, csv
x = open('test/dbTest.json')
rows = json.load(x)
with open('test.csv', 'wb+') as f:
dict_writer = csv.DictWriter(f, fieldnames=['leaderboard', 'users'])
dict_writer.writeheader()
dict_writer.writerow(rows)
我試圖將字段名稱更改為 'userId' 、 'userName' 等,但隨后出現錯誤:
ValueError: dict 包含不在 fieldnames 中的字段:u'users', u'leaderboard'
如何提取我需要的數據? 為什么上面的代碼不正確?
此外,CSV 應如下所示:
userId,userName,score,gameType,dateCreated,_id,
1432024286216,Joe Bloggs,111111,standard,1432024397833,1432024397833
1432024626556,Jane Bloggs,222222,demo,1432024730861,1432024730861
並澄清一下,“用戶”和“排行榜”因字段名稱不同而不同。
# json_data being the literal file data, in this example
import json
import csv
data = json.loads(json_data)['leaderboard']['$']
with open('/tmp/test.csv', 'w') as outf:
dw = csv.DictWriter(outf, data[0].keys())
dw.writeheader()
for row in data:
dw.writerow(row)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.