树状结构扁平化处理

有这样一个树状结构:

复制代码
data = [
        {
            "id":1,
            "name":"吃喝",
            "parentId":0,
            "children":[
                {
                    "id":2,
                    "name":"烧烤",
                    "parentId":"1",
                    "children":[]
                },
                {
                    "id":5,
                    "name":"奶茶",
                    "parentId":"1",
                    "children":[]
                }
            ]
        },
        {
            "id":3,
            "name":"玩乐",
            "parentId":0,
            "children":[
                {
                    "id":4,
                    "name":"ktv",
                    "parentId":"3",
                    "children":[]
                },
                {
                    "id":6,
                    "name":"棋牌室",
                    "parentId":"3",
                    "children":[]
                }
            ]
        }
    ]
复制代码

现在要将其扁平化处理,存进自关联表里,可以编写函数:

复制代码
def func(source, result, parent_id):
    """树状结构扁平化处理"""
    if source:
        for item in source:
            _dict = deepcopy(item)
            _dict.pop("children")
            result.append(_dict)
            tree_zip(item.get("children"), result, item.get("id"))
    return result
复制代码

调用方式:

func(data, [], 0)

 结果:

data = [
      {'id': 1, 'name': '吃喝', 'parentId': 0},
      {'id': 2, 'name': '烧烤', 'parentId': '1'},      {'id': 5, 'name': '奶茶', 'parentId': '1'},
      {'id': 3, 'name': '玩乐', 'parentId': 0},      {'id': 4, 'name': 'ktv', 'parentId': '3'},
      {'id': 6, 'name': '棋牌室', 'parentId': '3'}
]

 

posted @   子非鱼且于  阅读(382)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
Live2D
欢迎阅读『树状结构扁平化处理』
点击右上角即可分享
微信分享提示