我有一个数组:
Array
(
[0] => Array
(
[setid] => 2
[income] => 100
)
[1] => Array
(
[setid] => 2
[income] => 120
)
[2] => Array
(
[setid] => 3
[income] => 700
)
)
我需要找到相同setid的托管,将他们的收入加起来并删除重复的托管 - 最后它应该是这样的:
Array
(
[0] => Array
(
[setid] => 2
[income] => 220
)
[1] => Array
(
[setid] => 3
[income] => 700
)
)
是否有人知道我的问题的解决方案,或者我必须走很长的路并手动完成每一步?
谢谢和问候
答案 0 :(得分:4)
只需创建一个新数组,使用set id作为键即可快速寻址。并在最后重新索引数组。
$result = array();
foreach ($array as $val) {
if (!isset($result[$val['setid']]))
$result[$val['setid']] = $val;
else
$result[$val['setid']]['income'] += $val['income'];
}
$result = array_values($result); // reindex array
答案 1 :(得分:1)
这应该有效:
$values = array();
foreach($array as $val) {
if(isset($values[$val['setid']])) {
$values[$val['setid']] += $val['income'];
} else {
$values[$val['setid']] = $val['income'];
}
}
//all values are now in $values array, keys are setid and values are income
答案 2 :(得分:0)
编写自己的功能,这根本不是很长的路。
$result = array_reduce($originalArray, function($memo, $item){
isset($memo[$item['setid']])
? $memo[$item['setid']] = $item['income']
: $memo[$item['setid']] += $item['income'];
return $memo;
}, []);
答案 3 :(得分:0)
您应该使用php官方网站提供的array_unique功能。
一个例子:
<?php
$input = array("a" => "green", "red", "b" => "green", "blue", "red");
$result = array_unique($input);
print_r($result);
?>
输出:
Array
(
[a] => green
[0] => red
[1] => blue
)
要对重复的值求和,您可以使用array_count_values函数:
<?php
$array = array(1, "hello", 1, "world", "hello");
print_r(array_count_values($array));
?>
输出将是:
Array
(
[1] => 2
[hello] => 2
[world] => 1
)