树状结构扁平化处理
有这样一个树状结构:
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'}
]
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通