[英]Return keys from nested dictionary Python
我有一個這樣的嵌套字典:
{'needed1': {'notneeded': {'needed2': 'some_value'},
'notneeded2': {'needed2': 'some_value'},
'notneeded3': {'needed3: 'some_value', 'needed4': 'some_value'},
'notneeded4': {'needed3': 'some_value', 'needed4': 'some_value'}}}
我在其中寫了一個這樣的函數:
def get_field_names(category):
field_names = []
for info_cat, cat_type in category.items():
# first key -> needed
field_names.append(info_cat)
for category_type, conditions in cat_type.items():
# second key -> not needed
for field in conditions.keys():
# third key -> needed
if field not in field_names:
field_names.append(field)
return field_names
其中需要字典頂部的鍵和嵌套字典(第 3 級)內的鍵。 這將返回一個唯一列表(按嵌套順序)我需要從級別 1 和 3 的鍵。此代碼有效,但我不知道如何或是否有更優雅的方式來編寫它。 我想進一步了解處理這種情況的方法,以顯式處理 a 中的嵌套級別以提取我選擇的鍵/值
這可以幫助您獲得所需的輸出,
def get_all_keys(mydict):
for key, value in mydict.items():
yield key
if type(value) == dict:
yield from get_all_keys(mydict[key])
keys = set(map(lambda key:key if ("not" not in key) else None, get_all_keys(data))) - {None}
我為此得到了@DmitryTorba 的答案的幫助。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.