如果php laravel中有相同的键,如何将关联数组中的值求和

如下所示的简单代码:

        $array = [
            [11 => 771725],
            [11 => 847226],
            [10 => 410035],
            [11 => 455387],
        ];
        dd($array);

输出:

10月(10日)结果有1价:

["410035"]

11月(11日)有3个价格:

["771725", "847226", "455387"]

和在12月(12)为无

我需要逻辑来计算10个月、11个月和12个月的所有价格。 预期输出为

[
    10 => "2074338",
    11 => "410035",
    12 => "0"
]

谢谢:)


解决方案

我使用了Collection,最终得到了正确的结果。这可以通过以下几种方式实现:

方法1:

collect($array)
    ->groupBy(function ($item) {
        return collect($item)->keys()->first();
    })
    ->map(function ($items) {
        return collect($items)->flatten()->sum();
    });

方法2:

collect($array)
    ->groupBy(function ($item) {
        return array_key_first($item);
    })
    ->map(function ($items) {
      return collect($items)->flatten()->sum();
    });

方法3:

$default = [
    1 => 0, 
    2 => 0,
    3 => 0,
    4 => 0,
    5 => 0,
    6 => 0,
    7 => 0,
    8 => 0,
    9 => 0,
    10 => 0,
    11 => 0,
    12 => 0,
];

collect($array)
    ->reduce(function ($carry, $item) {
        $month = array_key_first($item);
  
        $carry[$month] += $item[$month];
  
        return $carry;
    }, $default);

相关文章