PHP数组合并:如何高效地将两个数组按照指定个数分组并求和?(数组.求和.高效.分组.合并...)

wufei123 发布于 2025-03-14 阅读(8)

php数组合并:如何高效地将两个数组按照指定个数分组并求和?

高效PHP数组处理:按指定数量分组并求和

在PHP开发中,常常需要对数组进行分组和求和操作。本文将演示如何高效地将两个PHP数组按照指定数量分组,并计算每组数值的总和。

假设我们有两个数组:categories 数组包含日期数据,data 数组包含对应日期的数值数据。我们需要将这两个数组按每6个日期为一组进行合并,并计算每组数值的总和。原始数组如下:

$arr = array(
    'categories' => array(
        '22-01-30', '22-01-31', '22-02-01', '22-02-02', '22-02-03', '22-02-04',
        '22-02-05', '22-02-06', '22-02-07', '22-02-08', '22-02-09', '22-02-10',
        '22-02-11', '22-02-12', '22-02-13', '22-02-14', '22-02-15', '22-02-16',
        '22-02-17', '22-02-18', '22-02-19', '22-02-20', '22-02-21', '22-02-22',
        '22-02-23', '22-02-24', '22-02-25', '22-02-26', '22-02-27', '22-02-28'
    ),
    'data' => array(
        0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5638.04, 0.00, 0.00, 0.00, 0.00, 0.00,
        0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 0.00, 25915.99, 1606.44,
        1676.90, 0.00, 0.00, 1203.08
    )
);

目标是将上述数组合并成如下形式:

array(
    'categories' => array(
        '22-01-30/22-02-04', '22-02-05/22-02-10', '22-02-11/22-02-16',
        '22-02-17/22-02-22', '22-02-23/22-02-28'
    ),
    'data' => array(
        0.00, 5638.04, 0.00, 0.00, 30402.41
    )
);

我们可以通过以下代码实现:

$groupSize = 6;
$newCategories = [];
$newData = [];
$categories = $arr['categories'];
$data = $arr['data'];

for ($i = 0; $i < count($categories); $i += $groupSize) {
    $groupCategories = array_slice($categories, $i, $groupSize);
    $groupData = array_slice($data, $i, $groupSize);
    $newCategories[] = implode('/', $groupCategories);
    $newData[] = array_sum($groupData);
}

$result = array(
    'categories' => $newCategories,
    'data' => $newData
);

print_r($result);

这段代码使用循环和array_slice 函数将数组分割成指定大小的块,implode 函数将日期连接起来,array_sum 函数计算每组的数值总和。最终得到目标数组。 这种方法高效地处理了数组分组和求和操作。

以上就是PHP数组合并:如何高效地将两个数组按照指定个数分组并求和?的详细内容,更多请关注知识资源分享宝库其它相关文章!

标签:  数组 求和 高效 

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。