[英]Python Edit/Rename Key Names in .json
有沒有辦法更改密鑰名稱? 我需要像示例中那樣更改名稱"Class123"
。 我可以更改值,但我不知道如何更改鍵名。
示例 .json :
{
"Class123": "classvalue",
"name1": {
"name2": {
"name3": {
"Y": 158.8,
"X": 201.46
},
"name4": {
"Y": 159.68,
"X": 200.32
}
}
}
}
像這樣開始:
with open('my.json') as json1:
data = json.load(json1)
for item in data:
沒有辦法“改變”一個鍵名。 您能做的最好的事情是使用pop
將值復制到另一個鍵:
d = {'old_name': 1}
d['new_name'] = d.pop('old_name')
print(d)
# {'new_name': 1}
我想在這里添加我的方法,因為它將單數命名擴展為使用鍵的字典。
假設您有一個示例 JSON 列表ga_list
並且您想使用字典鍵names_key
更改所有名稱:
names_key = { 'ga:date' : 'date' ,
'ga:bounceRate' : 'bounce' ,
'ga:newUsers' : 'new_users',
'ga:pageviews' : 'page_views',
'ga:sessions' : 'sessions',
'ga:uniquePageviews' : 'unique_page_views',
'ga:users' : 'users'
}
ga_list = [{
'ga:bounceRate': 34.478408,
'ga:date': '20151203',
'ga:newUsers': 1679,
'ga:pageviews': 550,
'ga:sessions': 307,
'ga:uniquePageviews': 467,
'ga:users': 256},
{'ga:bounceRate': 21.28534,
'ga:date': '20151204',
'ga:newUsers': 164,
'ga:pageviews': 594,
'ga:sessions': 305,
'ga:uniquePageviews': 476,
'ga:users': 252},
{'ga:bounceRate': 13.8372346,
'ga:date': '20151205',
'ga:newUsers': 152,
'ga:pageviews': 826,
'ga:sessions': 330,
'ga:uniquePageviews': 241,
'ga:users': 200}]
for row in ga_list:
for k, v in names_key.items():
for old_name in row:
if k == old_name:
row[v] = row.pop(old_name)
print(ga_list)
>>>
[{'bounce': 34.47842608,
'date': '20151203',
'new_users': 1679,
'page_views': 550,
'sessions': 307,
'unique_page_views': 467,
'users': 256},
{'bounce': 21.28534,
'date': '20151204',
'new_users': 164,
'page_views': 594,
....
'unique_page_views': 241,
'users': 200}]
有了它,所有舊名稱都根據密鑰重命名。
希望這可以幫助某人。
類似的東西
your_dict[new_key] = your_dict.pop(old_key)
從您的 dict 中刪除舊密鑰並創建一個新密鑰。
一種方法是使用 replace() 函數,但請確保您必須先將 JSON Dict 轉換為 String,因為 Dictionary 的鍵無法更改。
json_data = json_data.replace('key_old1','Key_new1').replace('key_old2','key_new2')
希望這會有所幫助。 干杯……!!
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.