0

0

如何递归构建带完整路径的嵌套字典结构

聖光之護

聖光之護

发布时间:2025-12-31 13:52:44

|

112人浏览过

|

来源于php中文网

原创

如何递归构建带完整路径的嵌套字典结构

本文介绍如何通过递归函数为嵌套字典中的每个节点添加 folder 字段,其值为从根节点到当前节点的完整路径(如 'kestral/burtree lane/archive'),并修正因重复拼接导致的路径错误。

在处理树形结构数据(如文件系统、组织架构或导航菜单)时,常需为每个节点生成其“全路径”用于展示、路由或存储。给定一个以 children 列表表示子节点的嵌套字典,目标是在不修改原结构的前提下,为每个节点新增 folder 键,其值为由根至该节点的 / 分隔路径

原始代码的问题在于:在递归调用中,既将 data["name"] 拼入了当前层级的 path,又在下一层再次使用 child["name"] 拼接——而 child 的 data["name"] 在子调用中又被重复追加,导致名称重复(如 "Burtree LaneBurtree Lane")。根本原因在于路径计算逻辑与递归参数传递耦合不当。

正确做法是:每层只负责计算“自身路径”,并将该路径(含末尾 /)作为前缀传给子节点,子节点在此基础上追加自己的 name 即可。以下是修复后的专业实现:

def build_structured_dict(data, parent_path=""):
    """
    递归为嵌套字典添加 'folder' 字段,表示从根到当前节点的完整路径。

    Args:
        data (dict): 当前节点字典,必须含 'name' 和 'children' 键
        parent_path (str): 父节点路径(不含当前节点名),默认为空字符串

    Returns:
        dict: 新建的结构化字典,含 'name', 'folder', 'children' 三字段
    """
    # 计算当前节点的完整路径
    current_path = f"{parent_path}{data['name']}" if parent_path else data['name']

    # 构建当前节点字典
    new_dict = {
        "name": data["name"],
        "folder": current_path,
        "children": []
    }

    # 递归处理每个子节点,传入当前路径 + '/' 作为新父路径
    for child in data["children"]:
        new_dict["children"].append(
            build_structured_dict(child, f"{current_path}/")
        )

    return new_dict

关键修正点说明

HTTPie AI
HTTPie AI

AI API开发工具

下载
  • parent_path 默认设为空字符串 "",避免开头出现冗余 /(如 "/Kestral"),严格匹配期望输出;
  • current_path 仅在本层计算一次,确保 name 不被重复拼接;
  • 递归调用时传入 f"{current_path}/" —— 这个带斜杠的前缀,让子节点只需直接拼接自身 name 即可得到正确路径。

? 使用示例

a = {
    'name': 'Kestral',
    'children': [
        {
            'name': 'Burtree Lane',
            'children': [
                {'name': 'ARCHIVE', 'children': []},
                {
                    'name': 'Development',
                    'children': [
                        {'name': 'Fee Proposals', 'children': []}
                    ]
                }
            ]
        }
    ]
}

result = build_structured_dict(a)
print(result['folder'])  # 输出: 'Kestral'
print(result['children'][0]['folder'])  # 输出: 'Kestral/Burtree Lane'
print(result['children'][0]['children'][1]['children'][0]['folder'])  # 输出: 'Kestral/Burtree Lane/Development/Fee Proposals'

⚠️ 注意事项

  • 输入字典必须保证每个节点均含 name(字符串)和 children(列表)键,否则会触发 KeyError。生产环境建议增加类型校验或异常处理;
  • 若需支持空 children 为 None 的情况,可在循环前添加 if data.get("children"): 判断;
  • 路径分隔符 / 可按需替换为 \(Windows)或 os.sep 实现跨平台兼容。

该方案简洁、可读性强,且完全符合函数式递归设计原则:每一层只关注自身状态,路径状态通过参数单向传递,无副作用,易于测试与复用

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

711

2023.08.22

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

248

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

205

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1435

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

609

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

547

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

539

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

157

2025.07.29

小游戏4399大全
小游戏4399大全

4399小游戏免费秒玩大全来了!无需下载、即点即玩,涵盖动作、冒险、益智、射击、体育、双人等全品类热门小游戏。经典如《黄金矿工》《森林冰火人》《狂扁小朋友》一应俱全,每日更新最新H5游戏,支持电脑与手机跨端畅玩。访问4399小游戏中心,重温童年回忆,畅享轻松娱乐时光!官方入口安全绿色,无插件、无广告干扰,打开即玩,快乐秒达!

30

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.3万人学习

Excel 教程
Excel 教程

共162课时 | 10.1万人学习

PHP基础入门课程
PHP基础入门课程

共33课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号