PHP数组查找重复项,将它们求和并删除重复项。

6

我有一个数组:

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
    )
)

有没有人知道一个高级解决方案来解决我的问题,还是我必须走漫长的路逐步手动解决?

谢谢和问候。

4个回答

5

只需创建一个新数组,并使用setid作为键来快速访问。最后重新索引数组。

$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

你可以使用array_reduce来更优雅地完成此操作,但是这里的代码也能胜任。 - bwoebi
@ bwoebi: 非常感谢!非常好用 - 对于我的逻辑有一个小修改(否定 if 语句): code if (!isset($result[$val['mitarbeiter_id']])) code 否则它将无法累加收入。 - Stefan

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

实际上,你首先需要创建一个数组,其中键是setid... - bwoebi
我修改了答案,这样你就不必再做了。 - Pitchinnate
呵呵,现在它几乎看起来像是我的答案 :-) - bwoebi
是的,以前它可以工作,但现在它只会抛出一个通知。 - Pitchinnate

0

编写自己的函数,这并不是一条漫长的道路。

$result = array_reduce($originalArray, function($memo, $item){

  isset($memo[$item['setid']])
    ? $memo[$item['setid']] = $item['income']
    : $memo[$item['setid']] += $item['income'];
  return $memo;

}, []);

-1
你应该使用 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
)

4
这将计算数量而非求和数值。 - Sal00m

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接