二维数组中特定列的总和

问题描述 投票:0回答:3

我的代码中有这个数组

Array
(
    [1] => Array
        (
            [1] => 4
            [5] => 7
        )

    [2] => Array
        (
            [1] => 2
            [5] => 5
        )

    [3] => Array
        (
            [1] => 2
            [5] => 5
        )

    [4] => Array
        (
            [1] => 6
            [5] => 9
        )

    [5] => Array
        (
            [1] => 6
            [5] => 8
        )

)
1

如何获得具有相同索引的元素的总和?例如 - 索引为

5
或索引
1
的所有元素的总和。是否可以不对列/键值进行硬编码?

php arrays multidimensional-array sum array-sum
3个回答
6
投票

您可以使用此代码

这是测试的演示代码

$items = array(
 array(1 => 1, 2 => 'White Shirt', 3 => 2),
 array(1 => 2, 2 => 'Blue Shirt', 3 => 3)
);
echo "<pre>";
print_r($items);

echo array_sum(array_column($items, 3)); // output 5

it will work for php 5.5+
 // PHP 5.5+
 echo array_sum(array_column($array, 'yourindexname')); // 

// PHP 4+
function sumArray($item) {
return $item['yourindex'];
}

echo array_sum(array_map('sumArray', $array));

/ PHP 5.3+
echo array_sum(array_map(
function($item) {
    return $item['yourindex'];
}, $items)
);



$sumvalue = array();

foreach ($array as $k=>$sub_array) {
  foreach ($sub_array as $id=>$value) {
  $sumvalue [$id]+=$value;
}
}

 print_r($sumvalue );

1
投票

您可以执行以下操作:

function getSumOfId($array, $id) {
   $sumOfId = 0;

   foreach($array as $arr) {
      $sumOfId += $arr[$id];
   }
   return $sumOfId;
}

这样您将循环遍历所有数组,并获得特定 ID 的完整总和。

你可以这样使用它

getSumOfId($yourArray, 5)


1
投票

您可以使用

array_reduce()
来求和目标值。

$sum = array_reduce($arr, function($carry, $item){
    $carry += $item[5];
    return $carry;
});
echo $sum;

demo

中检查代码结果
© www.soinside.com 2019 - 2024. All rights reserved.