我正在处理复杂的嵌套字典和列表数据结构。我需要展平数据并将所有嵌套项目提升至 0 级。请参阅下面的示例以了解更多信息:
{a:1,b:2,c:{c1:[{c11:1,c12:2,c13:3},{c21:1,c22:2,c23:3}],d1:[{d11:1,d12:2,d13:3},{d21:1,d22:2,d23:3}]},x:1,y:2}
我需要将其压平为:
{a:1,b:2,c_c1_c11:1, c_c1_c12:2,c_c1_c13:3,c_c1_c21:1,c_c1_c22:2,c_c1_c23:3, c_d1,d11:1...and so on}
我参考了第一个答案这个帖子 https://stackoverflow.com/questions/28131446/get-nested-arrays-out-of-a-dictionary#,但只有当我有嵌套字典时它才能工作,而如果列表嵌套在字典中并且更多字典嵌套在这些列表中,则它不起作用。
我稍微修改了代码以适合我的用例,但此代码不起作用
def flattenDict(d):
node_map = {}
node_path = []
def nodeRecursiveMap(d, node_path):
for key, val in d.items():
if ((type(val) is not dict)&(type(val) is not list)):
node_map['_'.join(node_path + [key])] = val
if type(val) is list:
def nodeListRecursion(val,node_path):
for element in val:
if ((type(element) is not dict)&(type(element) is not list)) : node_map['_'.join(node_path + [key])] = element
if type(element) is list: nodeListRecursion(element,node_map)
if type(element) is dict: nodeRecursiveMap(element, node_path + [key])
nodeListRecursion(val,node_path)
if type(val) is dict: nodeRecursiveMap(val, node_path + [key])
nodeRecursiveMap(d, node_path)
return node_map
当我将代码粘贴到此处时,缩进变得混乱。但我真的很感激这里的任何帮助。