我想合并这两个数组,并在保持movements
的同时将值day
的总和。
第一个数组:
array (30)
0 => array (2)
day => "01" (2)
movements => 49
1 => array (2)
day => "02" (2)
movements => 50
2 => array (2)
day => "03" (2)
movements => 54
...
第二个数组:
array (30)
0 => array (2)
day => "01" (2)
movements => 50
1 => array (2)
day => "02" (2)
movements => 51
2 => array (2)
day => "03" (2)
movements => 41
...
结果我期待,一组数组具有相同的day
索引和movements
的总和:
array (30)
0 => array (2)
day => "01" (2)
movements => 99
1 => array (2)
day => "02" (2)
movements => 101
2 => array (2)
day => "03" (2)
movements => 95
...
非常感谢任何帮助。
答案 0 :(得分:1)
如果有任何数组错过任何一天,甚至可以计算运动。
<?php
$arrayFirst = [
['day' => '01', 'movements' => 10],
['day' => '02', 'movements' => 20],
['day' => '04', 'movements' => 40],
];
$arraySecond = [
['day' => '01', 'movements' => 15],
['day' => '03', 'movements' => 30],
['day' => '04', 'movements' => 45],
];
$arrColFirst = array_column($arrayFirst, 'movements', 'day');
$arrColSecond = array_column($arraySecond, 'movements', 'day');
$merrgedArray = array_merge($arrColFirst, $arrColSecond);
$result = [];
foreach ($merrgedArray as $day=> $movments) {
$result[$day] = [
'day' => $day,
'movements' => isset($arrColFirst[$day]) ? $arrColFirst[$day] + $movments : $movments,
];
}
sort($result);
答案 1 :(得分:1)
$arr1 = [ ['day' => '01', 'movement' => 50], ['day' => '02', 'movement' => 10] ];
$arr2 = [ ['day' => '01', 'movement' => 20], ['day' => '02', 'movement' => 10] ];
$sum = [];
echo '<pre>';
print_r($arr1);
print_r($arr2);
if(!empty($arr1)){
$result = [];
foreach ($arr1 as $key => $value) {
if(isset($arr2[$key]['day']) && $arr2[$key]['day'] == $value['day']){
$result['day'] = $value['day'];
$result['movement'] = $value['movement']+$arr2[$key]['movement'];
}
array_push($sum, $result);
}
}
print_r($sum);