如何高效合并PHP数组,实现日期与数值的按组求和?(求和.高效.数组.数值.合并...)

wufei1232025-03-24PHP3

高效合并php数组:按日期分组求和

本文演示如何高效合并PHP数组,特别是处理包含日期和数值数据的数组,并按组进行求和。示例展示了如何将日期数组和数值数组合并,并按指定组数进行分组汇总。

原始数据:

$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
    )
);

目标:将数组按每6个元素一组进行合并,并计算每组数值的总和。

预期结果:

$result = 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;
$categories = $arr['categories'];
$data = $arr['data'];
$newCategories = [];
$newData = [];

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);

代码解释:

  1. 设置 $groupSize 为每组的元素个数。
  2. 使用 for 循环,每次迭代处理 $groupSize 个元素。
  3. array_slice 函数提取每组的日期和数值。
  4. implode 函数将每组日期连接成字符串。
  5. array_sum 函数计算每组数值的总和。
  6. 将结果存储到 $result 数组中。

如何高效合并PHP数组,实现日期与数值的按组求和?

此方法简洁高效,易于理解和维护。 请注意,图片路径 /uploads/20250306/174120529767c8af3185b80.jpg 需要替换成实际的图片路径才能正常显示。

以上就是如何高效合并PHP数组,实现日期与数值的按组求和?的详细内容,更多请关注知识资源分享宝库其它相关文章!

发表评论

访客

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