我想用Python创建一个递归方法来打印此字典:
partners = {
'manager-1': {
'name': 'Manager 1',
'children': {
'manager-2': {
'name': 'Manager 2',
'children': {
'employee-1': {
'name': 'Employee 1',
'children': {
'employee-7': {
'name': 'Employee 7',
},
'employee-8': {
'name': 'Employee 8',
}
}
},
'employee-2': {
'name': 'Employee 2',
},
'employee-3': {
'name': 'Employee 3',
},
},
},
'manager-3': {
'name': 'Manager 3',
'children': {
'employee-4': {
'name': 'Employee 4',
},
'employee-5': {
'name': 'Employee 5',
},
'employee-6': {
'name': 'Employee 6',
},
},
},
'manager-4': {
'name': 'Manager 4',
},
'manager-5': {
'name': 'Manager 5',
}
}
}
}
并给出如下信息:
--Manager 1
----Manager 2
------Employee 1
--------Employee 7
--------Employee 8
------Employee 2
------Employee 3
----Manager 3
------Manager 4
------Manager 5
------Manager 6
----Manager 4
----Manager 5
我做了这个方法:
def hierarch(partners):
for partner in partners:
if 'children' not in partner.keys():
print(partner['name'])
else:
hierarch(partner['children'])
运行代码时出现此错误:
AttributeError: 'str' object has no attribute 'keys'
如何制作允许我打印此层次结构的脚本?我对字典不是很满意。我正在使用Python3。请提供任何帮助?谢谢。
答案 0 :(得分:5)
您需要重现准确的订单吗?您可以使用类似这样的方法遍历数据结构:
def recurse(data, level):
if type(data) is dict:
if "name" in data:
print("-" * level + data["name"])
for (key, value) in data.items():
recurse(value, level + 1)
recurse(partners, 1)
答案 1 :(得分:0)
之所以会得到AttributeError
,是因为您在每个“儿童”值上递归调用了hierarch
函数。这对于像'employee-1'这样的键是有效的,因为递归调用将在关联的字典上循环,但是在'name'上将失败,因为没有关联的字典,只有一个名称字符串。
因此,您需要测试每个项目,以查看递归是否有效。您可以使用type
函数,但是建议使用功能更强大的isinstance
函数。
我们可以通过将函数转换为生成器来使函数更灵活,而不是打印所需的名称。这样一来,我们就可以遍历生成的结果,随时打印结果,或者执行其他一些处理。或者我们可以轻松地将它们收集到列表或新的平面词典中。
partners = {
'manager-1': {
'name': 'Manager 1',
'children': {
'manager-2': {
'name': 'Manager 2',
'children': {
'employee-1': {
'name': 'Employee 1',
'children': {
'employee-7': {
'name': 'Employee 7',
},
'employee-8': {
'name': 'Employee 8',
}
}
},
'employee-2': {
'name': 'Employee 2',
},
'employee-3': {
'name': 'Employee 3',
},
},
},
'manager-3': {
'name': 'Manager 3',
'children': {
'employee-4': {
'name': 'Employee 4',
},
'employee-5': {
'name': 'Employee 5',
},
'employee-6': {
'name': 'Employee 6',
},
},
},
'manager-4': {
'name': 'Manager 4',
},
'manager-5': {
'name': 'Manager 5',
}
}
}
}
def show(obj, depth=0):
depth += 1
for v in obj.values():
if isinstance(v, dict):
yield from show(v, depth)
else:
yield v, depth
for v, depth in show(partners):
print('-' * depth + v)
输出
--Manager 1
----Manager 2
------Employee 1
--------Employee 7
--------Employee 8
------Employee 2
------Employee 3
----Manager 3
------Employee 4
------Employee 5
------Employee 6
----Manager 4
----Manager 5