扁平化的目录表转换为嵌套数组
创始人
2024-12-05 01:30:50
0

以下是一个将扁平化的目录表转换为嵌套数组的解决方法的代码示例:

def create_nested_array(directories):
    nested_array = []
    for directory in directories:
        path = directory['path']
        parts = path.split('/')
        current_level = nested_array
        for part in parts:
            existing_dir = next((d for d in current_level if d['name'] == part), None)
            if existing_dir:
                current_level = existing_dir['children']
            else:
                new_dir = {'name': part, 'children': []}
                current_level.append(new_dir)
                current_level = new_dir['children']
    return nested_array

使用示例:

directories = [
    {'path': 'root/dir1/dir2/file1.txt'},
    {'path': 'root/dir1/file2.txt'},
    {'path': 'root/file3.txt'},
    {'path': 'root/dir1/file4.txt'},
    {'path': 'root/dir3/file5.txt'}
]

nested_array = create_nested_array(directories)
print(nested_array)

输出:

[
    {
        'name': 'root',
        'children': [
            {
                'name': 'dir1',
                'children': [
                    {
                        'name': 'dir2',
                        'children': [
                            {
                                'name': 'file1.txt',
                                'children': []
                            }
                        ]
                    },
                    {
                        'name': 'file2.txt',
                        'children': []
                    },
                    {
                        'name': 'file4.txt',
                        'children': []
                    }
                ]
            },
            {
                'name': 'file3.txt',
                'children': []
            },
            {
                'name': 'dir3',
                'children': [
                    {
                        'name': 'file5.txt',
                        'children': []
                    }
                ]
            }
        ]
    }
]

这段代码首先创建一个空的嵌套数组 nested_array。然后遍历给定的目录表中的每个目录。对于每个目录,它将路径分割为部分,并使用一个循环来迭代每个部分。对于每个部分,它检查当前层级中是否已经存在一个具有相同名称的目录。如果存在,则将当前层级更新为该目录的 children,否则创建一个新的目录并将其添加到当前层级的 children 中。最后返回嵌套数组 nested_array

相关内容

热门资讯

三分钟了解!星悦手机麻将是不是... 三分钟了解!星悦手机麻将是不是挂,欢乐达人暗宝有辅助工具吗,必赢方法(有挂普及)1、欢乐达人暗宝有辅...
1分钟了解!星悦陕西麻将辅牌器... 1分钟了解!星悦陕西麻将辅牌器,小吆湖南跑得快有挂吗,详细教程(有挂方法)小吆湖南跑得快有挂吗辅助器...
5分钟了解!白金岛跑得快辅助工... 5分钟了解!白金岛跑得快辅助工具,友乐麻将赢牌,细节揭秘(有挂工具)一、白金岛跑得快辅助工具AI软件...
一分钟了解!兴动互娱,微乐福建... 一分钟了解!兴动互娱,微乐福建麻将有挂吗,微扑克教程(有挂透视)运微乐福建麻将有挂吗辅助工具,进入游...
1分钟了解!荆门手机麻将约战真... 1分钟了解!荆门手机麻将约战真的有挂吗,微乐家乡麻将怎么让系统发好牌,介绍教程(有挂教程);1、用户...
十分钟了解!欢聚斗地主真的有挂... 十分钟了解!欢聚斗地主真的有挂吗,皮皮跑胡子真的有外挂吗,wepoke教程(有挂机密)1、完成皮皮跑...
两分钟了解!老友游戏辅助器,财... 两分钟了解!老友游戏辅助器,财神13张 辅助器,细节方法(有挂ai代打);一、财神13张 辅助器AI...
两分钟了解!边锋斗地主约局小程... 两分钟了解!边锋斗地主约局小程序有挂吗,白金岛三打哈辅助器,实用技巧(有挂规律)暗藏猫腻,小编详细说...
5分钟了解!皮皮跑胡子辅助器最... 5分钟了解!皮皮跑胡子辅助器最新版,四川凉山跑得快辅助器,必备教程(有挂攻略)1、玩家可以在皮皮跑胡...
两分钟了解!阳光岛牌乐汇麻将有... 两分钟了解!阳光岛牌乐汇麻将有挂吗,旺旺福建麻将有什么攻略吗,力荐教程(有挂神器)1、每一步都需要思...