0

0

如何将扁平数组按 list_id 归组为结构化多维数组

心靈之曲

心靈之曲

发布时间:2026-02-04 12:55:00

|

136人浏览过

|

来源于php中文网

原创

如何将扁平数组按 list_id 归组为结构化多维数组

本文介绍一种高效、简洁的 php 方法,通过临时关联键对原始数组按 `list_id` 分组,再用 `array_values()` 重置索引,最终生成符合业务逻辑的嵌套结构——每个列表项包含基本信息及对应的产品子数组。

在实际开发中(如订单列表、购物清单等场景),我们常遇到“扁平化数据需按主键聚合为树形结构”的需求。例如,原始数据中每个元素既携带列表元信息(如 list_id 和 order_list_name),又内嵌一个产品条目,但相同 list_id 的条目分散在不同索引位置。目标是将其归并为:每个唯一 list_id 对应一个顶层数组项,其中包含列表头信息 + 所有归属该列表的产品子数组

✅ 推荐实现方案(健壮且易读)

使用临时关联数组作为分组容器,以 list_id 为键暂存每组数据,避免重复初始化,并在循环结束后统一转为数字索引:

剪小映
剪小映

记录美好智能成片,AI智能视频剪辑

下载
$grouped = [];
foreach ($records as $record) {
    $listId = $record['list_id'];

    // 初始化该 list_id 对应的顶层结构(仅首次触发)
    if (!isset($grouped[$listId])) {
        $grouped[$listId] = [
            'list_id'         => $listId,
            'order_list_name' => $record['order_list_name']
        ];
    }

    // 追加产品数据(自动分配数字索引,如 [0], [1], ...)
    $grouped[$listId][] = [
        'list_id'      => $listId,
        'product_id'   => $record['product_id'] ?? null, // 注意:原示例中混用了 $product->xxx,此处统一用 $record 键
        'product_name' => $record['product_name'] ?? '',
        'sku'          => $record['sku'] ?? '',
        'qty'          => $record['qty'] ?? 0
    ];
}

// 移除临时关联键,返回标准数字索引数组
$result = array_values($grouped);
print_r($result);
? 关键点说明: 利用 $grouped[$listId] 作为“桶”进行分组,天然去重; [] 追加语法确保产品子数组按顺序填入,索引自动递增; array_values() 消除关联键依赖,输出与预期完全一致的纯数字索引结构。

⚠️ 注意事项与常见陷阱

  • 字段一致性校验:原始数据中部分字段(如 product_id)可能来自对象方法(如 $product->getId()),但在真实上下文中需确保 $record 已包含全部必要键,或提前完成对象映射,否则会触发 Notice: Undefined index。
  • 避免覆盖风险:若省略 isset() 判断而直接赋值(如 $grouped[$listId]['list_id'] = ...),虽能运行,但每次循环都会重复写入头信息,降低性能且语义不清,不推荐用于生产环境。
  • 空值防护:建议对 product_id、qty 等关键字段添加 ?? 默认值处理,增强鲁棒性。
  • 扩展性考虑:如后续需支持多级嵌套(如分类 → 列表 → 产品 → SKU变体),可将此逻辑封装为递归函数或使用 array_reduce(),但对当前二维聚合而言,foreach 是最直观、可维护性最强的选择。

✅ 总结

该方案摒弃了复杂嵌套循环或低效的多次 array_filter() 调用,仅用一次遍历 + 哈希分组即完成结构重塑,时间复杂度为 O(n),空间可控,代码简洁且符合 PHP 最佳实践。掌握这种“临时键分组 + array_values() 收尾”的模式,可快速应对各类基于字段聚合的数组重构任务。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

139

2025.12.04

undefined是什么
undefined是什么

undefined是代表一个值或变量不存在或未定义的状态。它可以作为默认值来判断一个变量是否已经被赋值,也可以用于设置默认参数值。尽管在不同的编程语言中,undefined可能具有不同的含义和用法,但理解undefined的概念可以帮助我们更好地理解和编写程序。本专题为大家提供undefined相关的各种文章、以及下载和课程。

5505

2023.07.31

网页undefined是什么意思
网页undefined是什么意思

网页undefined是指页面出现了未知错误的意思,提示undefined一般是在开发网站的时候定义不正确或是转换不正确,或是找不到定义才会提示undefined未定义这个错误。想了解更多的相关内容,可以阅读本专题下面的文章。

3130

2024.08.14

网页undefined啥意思
网页undefined啥意思

本专题整合了undefined相关内容,阅读下面的文章了解更多详细内容。后续继续更新。

894

2025.12.25

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.02.06

java多线程方法汇总
java多线程方法汇总

本专题整合了java多线程面试题、实现函数、执行并发相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.02.06

1688阿里巴巴货源平台入口与批发采购指南
1688阿里巴巴货源平台入口与批发采购指南

本专题整理了1688阿里巴巴批发进货平台的最新入口地址与在线采购指南,帮助用户快速找到官方网站入口,了解如何进行批发采购、货源选择以及厂家直销等功能,提升采购效率与平台使用体验。

82

2026.02.06

快手网页版入口与电脑端使用指南 快手官方短视频观看入口
快手网页版入口与电脑端使用指南 快手官方短视频观看入口

本专题汇总了快手网页版的最新入口地址和电脑版使用方法,详细提供快手官网直接访问链接、网页端操作教程,以及如何无需下载安装直接观看短视频的方式,帮助用户轻松浏览和观看快手短视频内容。

15

2026.02.06

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

9

2026.02.06

热门下载

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

精品课程

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

共137课时 | 11.2万人学习

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

共6课时 | 11.2万人学习

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

共13课时 | 0.9万人学习

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

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