PHP一维数组如何高效转换为指定的多维树状结构?

php一维数组如何高效转换为指定的多维树状结构?

PHP数组结构转换:一维数组到多维树状结构的优雅实现

本文介绍如何将PHP一维数组高效地转换为指定的多维树状结构。假设我们有一个包含项目名称、型号和位置信息的数组,目标是将其转换为树形结构:项目名称作为一级节点,型号作为二级节点,位置作为三级节点。

初始一维数组:

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

目标多维数组结构:

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

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

为了避免使用中文键名带来的潜在问题,并构建出目标结构,我们可以采用以下高效的代码:

 "项目1", 'model' => "金", 'location' => '苏州'],    ['name' => "项目1", 'model' => "银", 'location' => '上海'],    ['name' => "项目2", 'model' => "铜", 'location' => '北京'],    ['name' => "项目2", 'model' => "铜", 'location' => '深圳'],];$result = [];foreach ($arr as $item) {    $name = $item['name'];    $model = $item['model'];    $location = $item['location'];    if (!isset($result[$name])) {        $result[$name] = ['name' => $name, 'child' => []];    }    $childIndex = array_search($model, array_column($result[$name]['child'], 'model'));    if ($childIndex === false) {        $result[$name]['child'][] = ['model' => $model, 'child' => []];        $childIndex = count($result[$name]['child']) - 1;    }    $result[$name]['child'][$childIndex]['child'][] = ['location' => $location];}$result = array_values($result); // 将关联数组转换为索引数组print_r($result);?>

这段代码首先迭代原始数组,然后根据项目名称、型号和位置信息逐步构建多维数组。它使用了array_searcharray_column函数来高效地查找和处理子节点,避免了嵌套循环,从而提高了效率。最后,array_values函数将结果转换为索引数组,与目标结构一致。 这种方法清晰易懂,并且避免了先前代码中过于复杂的嵌套array_map操作。

以上就是PHP一维数组如何高效转换为指定的多维树状结构?的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月10日 02:56:57
下一篇 2025年12月10日 02:57:10

相关推荐

发表回复

登录后才能评论
关注微信