标签:扁平化 树状 处理 children item result parentId id name
有这样一个树状结构:
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'}
]
标签:扁平化,树状,处理,children,item,result,parentId,id,name 来源: https://www.cnblogs.com/liudaya/p/16524692.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。