商城首页欢迎来到中国正版软件门户

您的位置:首页 >如何在 PHP 中按名称合并数组并累加指定字段值

如何在 PHP 中按名称合并数组并累加指定字段值

  发布于2026-04-12 阅读(0)

扫一扫,手机访问

如何在 PHP 中按名称合并数组并累加指定字段值

本文介绍如何在 PHP 中对包含重复名称的关联数组进行分组,并对指定数值字段(如 coef)执行求和操作,同时保留其他字段(如 visitCount)的原始值。

本文介绍如何在 PHP 中对包含重复名称的关联数组进行分组,并对指定数值字段(如 `coef`)执行求和操作,同时保留其他字段(如 `visitCount`)的原始值。

在实际开发中,我们常遇到需要对多维数组按某个键(如 "name")去重聚合的场景——例如统计同名用户的总系数、累计访问次数等。PHP 并未提供开箱即用的 groupSum() 函数,但可通过原生循环与临时索引高效实现。

核心思路是:以 name 为键构建临时关联数组,遍历时判断该名称是否已存在;若存在,则累加 coef 值;否则直接初始化。最后用 array_values() 转为纯数字索引数组,符合常规输出预期。

以下是完整、健壮的实现代码:

<?php
$params = [
    ["name" => "Robert", "visitCount" => 2, "coef" => "5.50"],
    ["name" => "Anna",   "visitCount" => 1, "coef" => "3.58"],
    ["name" => "Joe",    "visitCount" => 1, "coef" => "8.00"],
    ["name" => "Robert", "visitCount" => 2, "coef" => "1.50"],
];

$output = [];
foreach ($params as $item) {
    $name = $item['name'];

    if (isset($output[$name])) {
        // 累加 coef(自动类型转换:字符串转 float 后相加)
        $output[$name]['coef'] = round((float)$output[$name]['coef'] + (float)$item['coef'], 2);
        // visitCount 保持首次出现的值(按题意要求,非累加)
    } else {
        // 初始化:保留原始 visitCount 和 coef(转为浮点确保精度)
        $output[$name] = [
            'name'       => $name,
            'visitCount' => $item['visitCount'],
            'coef'       => round((float)$item['coef'], 2)
        ];
    }
}

// 转为顺序索引数组(去除 name 键依赖)
$result = array_values($output);

print_r($result);
?>

✅ 输出结果:

Array
(
    [0] => Array
        (
            [name] => Robert
            [visitCount] => 2
            [coef] => 7
        )
    [1] => Array
        (
            [name] => Anna
            [visitCount] => 1
            [coef] => 3.58
        )
    [2] => Array
        (
            [name] => Joe
            [visitCount] => 1
            [coef] => 8
        )
)

⚠️ 注意事项:

  • coef 字段原始为字符串,务必显式转换为 (float) 再运算,避免 PHP 隐式转换导致精度丢失(如 "5.50" + "1.50" 可能得 7.000000000000001);
  • 使用 round($sum, 2) 控制小数位,适配货币/系数类业务场景;
  • visitCount 按题目要求不累加,仅保留首次出现的值;如需改为求和,可将 $output[$name]['visitCount'] += $item['visitCount'];;
  • 若数据量极大(>10万条),可考虑使用 array_reduce() 提升可读性,但性能差异微乎其微;
  • 建议在生产环境添加 isset($item['name']) && isset($item['coef']) 校验,增强鲁棒性。

该方法时间复杂度为 O(n),空间复杂度为 O(k)(k 为唯一 name 数量),简洁高效,适用于绝大多数聚合需求。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注