二维数组:$data
Array
(
[0] => Array
(
[id] => 1
[count] => 3
)
[1] => Array
(
[id] => 1
[count] => 2
)
[2] => Array
(
[id] => 1
[count] => 2
)
[3] => Array
(
[id] => 2
[count] => 2
)
[4] => Array
(
[id] => 2
[count] => 2
)
[5] => Array
(
[id] => 3
[count] => 3
)
[6] => Array
(
[id] => 3
[count] => 1
)
[7] => Array
(
[id] => 4
[count] => 1
)
[8] => Array
(
[id] => 4
[count] => 1
)
)
根据id相同 count相加
$item=[];
foreach($data as $k=>$v){
if(!isset($item[$v['id']])){
$item[$v['id']] = $v;
}else{
$item[$v['id']]['count'] += $v['count'];
}
}
结果:得到新数组 $item
Array
(
[1] => Array
(
[id] => 1
[count] => 7
)
[2] => Array
(
[id] => 2
[count] => 4
)
[3] => Array
(
[id] => 3
[count] => 4
)
[4] => Array
(
[id] => 4
[count] => 2
)
)
上面是一个元素 假如要根据两个元素相等:
$arr=Array
(
[0] => Array
(
[id] => 65379
[amount] => 1
[sn] => MB12
),
[1] => Array
(
[id] => 65380
[amount] => 2
[sn] =>MB12
),
[2] => Array
(
[id] =>65380
[amount] => 1
[sn] => MB12
),
[3] => Array
(
[send_detail_id] => 65382
[amount] => 1
[sn] => SA12
)
)
如果两个字段id和sn相同才合并求和,结果应该是
Array
(
[0] => Array
(
[id] => 65379
[amount] => 1
[sn] => MB12
),
[1] => Array
(
[id] => 65380
[amount] => 3 //和后面的相加了,第一个就不能和他相加
[sn] =>MB12
),
[3] => Array
(
[id] => 65382
[amount] => 1
[sn] => SA12
)
)
foreach($arr as $v){
if(!isset($res[$v['id'].'_'.$v['sn']])){
$res[$v['id'].'_'.$v['sn']] = $v;
}else{
$res[$v['id'].'_'.$v['sn']]['amount'] += $v['amount'];
}
}
print_r(array_values($res));