当前位置: 代码网 > it编程>编程语言>Php > 如何用PHP将一维数组转换为三层嵌套的树状结构?

如何用PHP将一维数组转换为三层嵌套的树状结构?

2025年03月29日 Php 我要评论
本文探讨如何高效地将php一维数组转换为三层嵌套的树状结构。给定一个包含项目名称、型号和位置信息的数组,目标是将其转换为树形结构,项目名称作为一级节点,型号为二级节点,位置为三级节点。初始数组:$ar

如何用php将一维数组转换为三层嵌套的树状结构?

本文探讨如何高效地将php一维数组转换为三层嵌套的树状结构。给定一个包含项目名称、型号和位置信息的数组,目标是将其转换为树形结构,项目名称作为一级节点,型号为二级节点,位置为三级节点。

初始数组:

$arr = [
    ['name' => "项目1", 'model' => "金", 'location' => '苏州'],
    ['name' => "项目1", 'model' => "银", 'location' => '上海'],
    ['name' => "项目2", 'model' => "铜", 'location' => '北京'],
    ['name' => "项目2", 'model' => "铜", 'location' => '深圳'],
];
登录后复制

目标树状结构:

$target = [
    [
        'name' => "项目1",
        'child' => [
            ['model' => "金", 'child' => [['location' => '苏州']]],
            ['model' => "银", 'child' => [['location' => '上海']]],
        ]
    ],
    [
        'name' => "项目2",
        'child' => [
            ['model' => "铜", 'child' => [['location' => '北京'], ['location' => '深圳']]],
        ]
    ],
];
登录后复制

之前的解决方案过于复杂。我们可以采用更简洁、易于理解的方法,利用循环和条件判断来构建树状结构:

$result = [];
foreach ($arr as $item) {
    $name = $item['name'];
    $model = $item['model'];
    $location = $item['location'];

    // 查找或创建项目名称节点
    $nameindex = array_search($name, array_column($result, 'name'));
    if ($nameindex === false) {
        $result[] = ['name' => $name, 'child' => []];
        $nameindex = count($result) - 1;
    }

    // 查找或创建型号节点
    $modelindex = array_search($model, array_column($result[$nameindex]['child'], 'model'));
    if ($modelindex === false) {
        $result[$nameindex]['child'][] = ['model' => $model, 'child' => []];
        $modelindex = count($result[$nameindex]['child']) - 1;
    }

    // 添加位置节点
    $result[$nameindex]['child'][$modelindex]['child'][] = ['location' => $location];
}

print_r($result); // 输出转换后的树状结构
登录后复制

这段代码首先初始化一个空数组 $result。然后,它迭代原始数组 $arr 中的每个项目。对于每个项目,它查找是否存在对应的项目名称和型号节点。如果不存在,则创建新的节点。最后,它将位置信息添加到相应的型号节点下。 这种方法更清晰,也更容易维护。

这种方法避免了嵌套的 array_map 和 array_reduce,使其更易于理解和调试。 它直接操作数组,效率也更高。 选择适合自己项目的方法,并根据实际情况调整代码。

以上就是如何用php将一维数组转换为三层嵌套的树状结构?的详细内容,更多请关注代码网其它相关文章!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com