PHP前端开发

Python扁平列表如何高效转换为嵌套字典树结构?

百变鹏仔 5天前 #Python
文章标签 嵌套

python 树形递归的快捷方法

问题:

如何使用 python 内置包或函数实现树形递归,将给定的扁平列表转换为嵌套字典表示的树形结构?

回答:

立即学习“Python免费学习笔记(深入)”;

虽然 python 没有内置函数直接解决此问题,但可以使用数据结构和算法实现所需功能。以下是一个示例代码:

def build_tree(data, root_id=0):    tree = []    for item in data:        if item['fid'] == root_id:            children = build_tree(data, item['id'])            if children:                item['children'] = children            tree.append(item)    return treedata = [    {"id": 1, "name": "sql", "fid": 0},    {"id": 2, "name": "sql", "fid": 1},    {"id": 3, "name": "sql", "fid": 0},    {"id": 4, "name": "sql", "fid": 3},]tree = build_tree(data)print(tree)

解释:

通过修改代码以适应特定的数据结构和需求,可以修改此方法以满足各种树形递归场景。