![](/img/trans.png)
[英]How do I define a function to extract values from nested dictionary for each row in python
[英]How to extract values from each entry in nested dictionary?
我有一個程序,可以解析Maven依賴樹並按需要組織數據。 我不確定如何正確索引數據以返回它。 這是從Maven依賴樹解析器輸出的數據的摘要(使用pprint)。
[{'name': 'org.antlr'},
{'type': 'dependency'},
{'metadata': [{'groupId': 'org.antlr'},
{'artifactId': 'antlr4',
'children': [({'name': 'org.antlr'},
{'type': 'dependency'},
{'metadata': [{'groupId': 'org.antlr'},
{'artifactId': 'antlr4-runtime'}]}),
({'name': 'org.antlr'},
{'type': 'dependency'},
{'metadata': [{'groupId': 'org.antlr'},
{'artifactId': 'antlr-runtime'}]}),
({'name': 'org.antlr'},
{'type': 'dependency'},
{'metadata': [{'groupId': 'org.antlr'},
{'artifactId': 'ST4'}]}),
({'name': 'org.abego.treelayout'},
{'type': 'dependency'},
{'metadata': [{'groupId': 'org.abego.treelayout'},
{'artifactId': 'org.abego.treelayout.core'}]}),
({'name': 'org.glassfish'},
{'type': 'dependency'},
{'metadata': [{'groupId': 'org.glassfish'},
{'artifactId': 'javax.json'}]}),
({'name': 'com.ibm.icu'},
{'type': 'dependency'},
{'metadata': [{'groupId': 'com.ibm.icu'},
{'artifactId': 'icu4j'}]})]}]}]
我努力了:
pprint([name for name in parsedTree[0]])
要么
pprint(parsedTree[0:1])
或這些的變體,其中parsedTree是上面顯示的輸出。
最終,我只想使用遞歸或生成器僅返回每個名稱,以便為API調用准備此信息。 我不知道如何單獨索引和提取名稱(沒有元數據或類型)。 有沒有辦法做到這一點? 先感謝您。 我想分別獲得每個名稱,以便如果我執行類似Beans.name的操作,它將返回
org.antlr
org.antlr
org.antlr
org.antlr
org.antlr
org.abego.treelayout
org.glassfish
com.ibm.icu
我之前的回答是錯誤的,我認為這應該可行:
def get_all_names(parsed_tree, li):
if not isinstance(parsed_tree, list) and not isinstance(parsed_tree, tuple):
return li
def get_all_names_dict(dictionary, li):
if not isinstance(dictionary, dict):
get_all_names(dictionary, li)
return
for key in dictionary.keys():
if key == 'name':
li.append(dictionary[key])
elif isinstance(dictionary[key], dict):
get_all_names_dict(dictionary[key], li)
elif isinstance(dictionary[key], list):
get_all_names(dictionary[key], li)
elif isinstance(dictionary[key], tuple):
get_all_names(dictionary[key], tuple)
for val in parsed_tree:
get_all_names_dict(val, li)
return li
print('\n'.join(get_all_names(parsedTree, [])))
抱歉,久等了!
您只需要學習字典,元組和字典,即可使用關鍵字“名稱”搜索字典。 如果在這里需要其他類型,請將它們包括在相關的“實例”檢查中。
def get_nested_name(tree):
names = []
if isinstance(tree, (list, tuple)):
for branch in tree:
names.extend(get_nested_name(branch))
elif isinstance(tree, dict):
try:
names.append(tree['name'])
except KeyError:
# this dict dont have a "name" key, lets ignore it
pass
branches = filter(lambda x: isinstance(x, (list, dict, tuple)), tree.values())
for b in branches:
names.extend(get_nested_name(b))
return names
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.