高效合并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);
代碼解釋:
- 設置 $groupSize 為每組的元素個數。
- 使用 for 循環,每次迭代處理 $groupSize 個元素。
- array_slice 函數提取每組的日期和數值。
- implode 函數將每組日期連接成字符串。
- array_sum 函數計算每組數值的總和。
- 將結果存儲到 $result 數組中。
此方法簡潔高效,易于理解和維護。 請注意,圖片路徑 /uploads/20250306/174120529767c8af3185b80.jpg 需要替換成實際的圖片路徑才能正常顯示。
? 版權聲明
文章版權歸作者所有,未經允許請勿轉載。
THE END