0

0

PHP中将树状数组结构扁平化为列表的教程

DDD

DDD

发布时间:2025-10-13 09:21:31

|

251人浏览过

|

来源于php中文网

原创

PHP中将树状数组结构扁平化为列表的教程

本教程详细介绍了如何在php中将复杂的树状数组结构(包含嵌套的`children`元素)高效地扁平化为一个简单的、按`id`排序的列表数组。通过递归函数遍历树的每个节点,提取其核心数据并处理`parent_id`,最终生成一个易于处理的扁平化数据集,适用于数据存储、展示或进一步处理。

在PHP开发中,我们经常会遇到将层级数据(如菜单、分类、组织结构等)表示为树状数组的需求。这种结构直观地展现了数据之间的父子关系。然而,在某些场景下,例如将数据存储到数据库、进行全局搜索或以列表形式展示所有项时,我们需要将这种树状结构“扁平化”为一个简单的、一维的数组列表。本文将详细讲解如何通过递归方法实现这一转换。

1. 理解树状与扁平化数组结构

首先,我们来看一个典型的树状数组结构和它对应的扁平化数组结构。

原始树状数组示例: 一个包含id、name和children(子节点数组)的树状结构。顶级节点通常没有parent_id字段,或其parent_id为0或null。

$tree = [
    [
        "id" => 1,
        "name" => "id1",
        "children" => [
            [
                "id" => 2,
                "parent_id" => 1,
                "name" => "id2",
                "children" => [
                    ["id" => 5, "parent_id" => 2, "name" => "id5"]
                ]
            ],
            [
                "id" => 3,
                "parent_id" => 1,
                "name" => "id3",
                "children" => [
                    ["id" => 6, "parent_id" => 3, "name" => "id6"],
                    ["id" => 8, "parent_id" => 3, "name" => "id8"]
                ]
            ]
        ]
    ],
    [
        "id" => 4,
        "name" => "id4",
        "children" => [
            [
                "id" => 9,
                "parent_id" => 4,
                "name" => "id9",
                "children" => [
                    ["id" => 10, "parent_id" => 9, "name" => "id10"]
                ]
            ]
        ]
    ],
    ["id" => 7, "name" => "id7", "children" => []]
];

目标扁平化数组示例: 一个简单的数组列表,每个元素都是一个节点,包含id、parent_id和name,并且通常按id排序。

$array = [
    ['id'=> 1, 'parent_id' => 0, 'name' => 'id1'],
    ['id' => 2, 'parent_id' => 1, 'name'=> 'id2'],
    ['id' => 3, 'parent_id' => 1, 'name'=> 'id3'],
    ['id' => 4, 'parent_id' => 0, 'name'=> 'id4'],
    ['id' => 5,'parent_id' => 2, 'name'=> 'id5'],
    ['id' => 6, 'parent_id' => 3, 'name'=> 'id6'],
    ['id' => 7, 'parent_id' => 0, 'name'=> 'id7'],
    ['id' => 8, 'parent_id' => 3, 'name'=> 'id8'],
    ['id' => 9, 'parent_id' => 4, 'name'=> 'id9'], 
    ['id' => 10, 'parent_id' => 9, 'name'=> 'id10'],
];

注意,在扁平化数组中,即使是顶级节点,也需要明确指定parent_id(通常为0)。

2. 扁平化策略:递归遍历

将树状结构扁平化的最有效方法是使用递归。基本思路如下:

arXiv Xplorer
arXiv Xplorer

ArXiv 语义搜索引擎,帮您快速轻松的查找,保存和下载arXiv文章。

下载

立即学习PHP免费学习笔记(深入)”;

  1. 定义一个递归函数,它接受当前层级的节点数组和一个用于收集结果的引用数组。
  2. 遍历当前层级的每个节点。
  3. 对于每个节点:
    • 提取该节点的核心数据(id、name)。
    • 检查该节点是否有parent_id。如果没有(通常是顶级节点),则将其parent_id设置为默认值(如0)。
    • 将处理后的节点数据添加到结果数组中。
    • 如果该节点有子节点(即存在children数组且不为空),则递归调用自身,传入子节点数组。
  4. 所有节点遍历完成后,结果数组将包含所有扁平化的节点。

3. PHP 实现

我们将通过两个函数来实现扁平化:一个递归辅助函数 flattenTree,和一个主函数 flatTree,负责初始化和最终排序。

 1,
        "name" => "id1",
        "children" => [
            [
                "id" => 2,
                "parent_id" => 1,
                "name" => "id2",
                "children" => [
                    ["id" => 5, "parent_id" => 2, "name" => "id5"]
                ]
            ],
            [
                "id" => 3,
                "parent_id" => 1,
                "name" => "id3",
                "children" => [
                    ["id" => 6, "parent_id" => 3, "name" => "id6"],
                    ["id" => 8, "parent_id" => 3, "name" => "id8"]
                ]
            ]
        ]
    ],
    [
        "id" => 4,
        "name" => "id4",
        "children" => [
            [
                "id" => 9,
                "parent_id" => 4,
                "name" => "id9",
                "children" => [
                    ["id" => 10, "parent_id" => 9, "name" => "id10"]
                ]
            ]
        ]
    ],
    ["id" => 7, "name" => "id7", "children" => []]
];

// 执行扁平化操作
$array = flatTree($tree);

// 打印结果
print_r($array);

?>

4. 代码解析

  1. flattenTree(array $nodes, array &$result = []): array
    • 这是一个递归函数,负责实际的遍历和数据提取。
    • $nodes 参数是当前正在处理的节点数组。初始调用时,它将是整个 $tree 数组。在递归调用中,它将是某个节点的 children 数组。
    • &$result 参数是一个引用传递的数组。这意味着在函数内部对 $result 的修改会直接影响到函数外部的 $flatResult 变量,从而实现所有扁平化节点的

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2022

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1345

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1251

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

948

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1402

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1231

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1440

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1303

2023.11.13

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

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

精品课程

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

共137课时 | 8.2万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

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

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