python list列表转树形结构

# list转树形数据
def listtotree(datalist, fidname, idname, root=None):
    """
    list转树形数据
    :param datalist: 数据源 [{'ID': 1, 'NM': '人', 'FID': 0},{'ID': 2, 'NM': '男人', 'FID': 1}]
    :param root: 根节点(不传入root表示所有树,传入root表示一棵树)
    :param fidname: 父级ID名  FID
    :param idname: 自增加序号ID字段 ID
    :return: tree 数据
    示例:
        data = [{'ID': 1, 'NM': '人', 'FID': 0},
            {'ID': 2, 'NM': '男人', 'FID': 1},
            {'ID': 3, 'NM': '女人', 'FID': 1},
            {'ID': 4, 'NM': '狗', 'FID': 0},
            {'ID': 5, 'NM': '猫', 'FID': 0},
            {'ID': 6, 'NM': '狮子', 'FID': 0}]
        调用方法
        listtotree(data, 0, 'FID', 'ID')
    """
    rdata = []
    ids = []

    def t2(p):
        for i, item in enumerate(datalist):
            if i not in ids:
                if p[idname] == item[fidname]:
                    if 'chids' not in p.keys():
                        p["chids"] = []
                    p["chids"].append(item)
                    t2(item)
                    ids.append(i)

    for i, item in enumerate(datalist):
        if root != None:
            if i not in ids and item[fidname] == root:
                t2(item)
                ids.append(i)
                rdata.append(item)
        else:
            if i not in ids:
                t2(item)
                ids.append(i)
                rdata.append(item)

    return rdata

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值