如何高效合并PHP數組,實現日期與數值的按組求和?

高效合并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個元素一組進行合并,并計算每組數值的總和。

預期結果:

立即學習PHP免費學習筆記(深入)”;

$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 需要替換成實際的圖片路徑才能正常顯示。

? 版權聲明
THE END
喜歡就支持一下吧
點贊10 分享