0

0

PHP数组对象去重与属性汇总:高效数据处理技巧

心靈之曲

心靈之曲

发布时间:2025-07-22 14:44:10

|

693人浏览过

|

来源于php中文网

原创

PHP数组对象去重与属性汇总:高效数据处理技巧

本教程详细讲解如何在PHP中处理包含重复项的数组对象,通过指定关键属性(如user_id)对数据进行去重,并对另一数值属性(如point)进行累加求和。文章将演示如何利用array_reduce、array_column和array_sum等核心PHP函数,高效地实现数据的分组、聚合与重构,从而将原始复杂数据转化为简洁的汇总结果。

核心问题:数组对象的数据聚合

在数据处理中,我们经常会遇到需要对数组中的对象进行去重并汇总其特定属性的场景。例如,一个用户交易记录数组可能包含同一用户的多条记录,每条记录都有一个积分字段,我们需要将这些记录合并,并计算出每个用户的总积分。

假设我们有以下PHP数组,其中包含多个用户的积分记录:

$data = [
    [
        "user_id" => 2,
        "point" => 2
    ],
    [
        "user_id" => 16,
        "point" => 3
    ],
    [
        "user_id" => 2,
        "point" => 10
    ],
    [
        "user_id" => 2,
        "point" => 10
    ]
];

我们的目标是将其转换为以下形式,每个user_id只出现一次,且其point值是所有记录的总和:

[
    [
        "user_id" => 2,
        "point" => 22
    ],
    [
        "user_id" => 16,
        "point" => 3
    ]
]

解决方案:分步实现

实现这一目标的核心思路是首先根据关键属性(如user_id)将数据进行分组,然后对每个分组内的数值属性进行求和。

1. 数据预处理(可选):从JSON字符串转换

如果你的原始数据是JSON格式的字符串,你需要先使用json_decode函数将其转换为PHP数组。如果数据已经是PHP数组,则可以跳过此步骤。

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

// 假设 $jsonString 是从外部获取的JSON字符串
// $jsonString = '[{"user_id": 2, "point": 2}, {"user_id": 16, "point": 3}, {"user_id": 2, "point": 10}, {"user_id": 2, "point": 10}]';
// $data = json_decode($jsonString, true); // true表示解码为关联数组

在本教程的示例中,我们直接使用PHP数组字面量 $data。

2. 按指定键分组数据

这一步是实现去重和汇总的关键。我们可以使用array_reduce函数来遍历原始数组,并将具有相同user_id的元素归类到同一个子数组中。

Cardify卡片工坊
Cardify卡片工坊

使用Markdown一键生成精美的小红书知识卡片

下载
$groupedById = array_reduce($data, function ($accumulator, $item) {
    // 使用 user_id 作为键,将相同 user_id 的项归入同一个数组
    $accumulator[$item['user_id']][] = $item;
    return $accumulator;
}, []);

/*
此时 $groupedById 的结构将是:
Array
(
    [2] => Array
        (
            [0] => Array
                (
                    [user_id] => 2
                    [point] => 2
                )
            [1] => Array
                (
                    [user_id] => 2
                    [point] => 10
                )
            [2] => Array
                (
                    [user_id] => 2
                    [point] => 10
                )
        )
    [16] => Array
        (
            [0] => Array
                (
                    [user_id] => 16
                    [point] => 3
                )
        )
)
*/

array_reduce函数在这里充当了一个累加器,它遍历 $data 数组中的每个 $item,并根据 $item['user_id'] 将其添加到 $accumulator 数组中对应的键下。

3. 汇总每个分组的指定属性

现在,我们有了按user_id分组的数据。接下来,我们需要遍历这些分组,并计算每个分组中point属性的总和。

$result = [];
foreach ($groupedById as $userId => $items) {
    // 使用 array_column 提取当前分组所有元素的 'point' 值
    // 然后使用 array_sum 计算这些值的总和
    $sumPoints = array_sum(array_column($items, 'point'));

    // 构建最终结果数组中的一个元素
    $result[] = [
        'user_id' => $userId, // 使用分组的键作为 user_id
        'point' => $sumPoints
    ];
}

/*
此时 $result 的结构将是:
Array
(
    [0] => Array
        (
            [user_id] => 2
            [point] => 22
        )
    [1] => Array
        (
            [user_id] => 16
            [point] => 3
        )
)
*/

在这个步骤中,array_column($items, 'point') 能够从当前用户的所有记录中高效地提取出point值组成一个新数组,然后array_sum则对这个新数组进行求和。

完整示例代码

将上述所有步骤整合在一起,形成一个完整的解决方案:

 2,
        "point" => 2
    ],
    [
        "user_id" => 16,
        "point" => 3
    ],
    [
        "user_id" => 2,
        "point" => 10
    ],
    [
        "user_id" => 2,
        "point" => 10
    ]
];

// 1. (可选) 如果数据是JSON字符串,先解码
// $jsonString = '[{"user_id": 2, "point": 2}, {"user_id": 16, "point": 3}, {"user_id": 2, "point": 10}, {"user_id": 2, "point": 10}]';
// $data = json_decode($jsonString, true);

// 2. 按 user_id 分组数据
$groupedById = array_reduce($data, function ($accumulator, $item) {
    $accumulator[$item['user_id']][] = $item;
    return $accumulator;
}, []);

// 3. 汇总每个分组的 point 属性
$result = [];
foreach ($groupedById as $userId => $items) {
    $sumPoints = array_sum(array_column($items, 'point'));
    $result[] = [
        'user_id' => $userId,
        'point' => $sumPoints
    ];
}

// 输出最终结果 (通常会编码为JSON返回给前端或API)
echo json_encode($result, JSON_PRETTY_PRINT);

/*
输出:
[
    {
        "user_id": 2,
        "point": 22
    },
    {
        "user_id": 16,
        "point": 3
    }
]
*/

?>

注意事项

  • 数据类型: 确保要汇总的属性(如point)是数值类型。如果它们是字符串,PHP的array_sum会自动尝试将其转换为数值,但如果包含非数值字符,可能会导致意外结果。在处理来自外部或不确定来源的数据时,建议进行类型检查或强制转换。
  • 性能: 对于包含数百万甚至更多元素的超大型数组,这种方法可能不是最高效的。在极端情况下,可以考虑数据库级别的聚合操作(如果数据来源于数据库)或使用更底层的语言扩展(如C)来实现。然而,对于大多数Web应用场景,这种PHP原生数组函数组合的性能已经足够。
  • 灵活性:
    • 不同的分组键: 如果需要按其他属性(如product_id)分组,只需将$item['user_id']替换为$item['product_id']即可。
    • 不同的汇总操作: 除了求和,你还可以轻松地进行其他聚合操作,例如计算平均值(array_sum / count)、查找最大值(max)、最小值(min)或计数(count)。
    • 多个汇总属性: 如果需要汇总多个数值属性,可以在foreach循环内部对每个属性重复array_sum(array_column(...))的操作。

总结

本教程展示了如何利用PHP强大的数组处理函数,如array_reduce、array_column和array_sum,有效地解决数组对象去重和属性汇总的问题。通过先分组后聚合的策略,我们能够将复杂、重复的数据结构转化为简洁、有意义的汇总结果。掌握这些技巧对于高效处理PHP中的数据至关重要。

相关专题

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

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

2431

2023.09.01

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

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

1557

2023.10.11

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

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

1455

2023.10.11

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

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

951

2023.10.23

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

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

1414

2023.10.23

html怎么上传
html怎么上传

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

1234

2023.11.03

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

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

1445

2023.11.09

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

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

1305

2023.11.13

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

9

2026.01.12

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
誉天教育RHCE视频教程
誉天教育RHCE视频教程

共9课时 | 1.4万人学习

尚观Linux RHCE视频教程(二)
尚观Linux RHCE视频教程(二)

共34课时 | 5.7万人学习

尚观RHCE视频教程(一)
尚观RHCE视频教程(一)

共28课时 | 4.8万人学习

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

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