0

我想汇总所有 [Suggested] 字段。请问我该怎么做?我用php。

Array
(
    [0] => Array
        (
            [Id] => 4
            [Suggested] => 1322
            [proximite_r] => 30924.8470655462
        )

    [1] => Array
        (
            [Id] => 7
            [Suggested] => 773
            [proximite_r] => 32229.1036975145
        )
)

谢谢!

4

5 回答 5

7

给你,伙计:array_reduce()像老板一样

// PHP >= 5.3
$sum = array_reduce($items, function($sum, $item){
  return $sum += $item['Suggested'];
}, 0);

// PHP 5.2
function _sum($sum, $item){
  return $sum += $item['Suggested'];
}
$sum = array_reduce($items, '_sum', 0);

遗憾的是 PHP <= 5.2 不支持闭包,所以你必须单独定义函数。

于 2012-12-24T21:16:54.663 回答
6

你可以试试这个:

$Sum = 0;
foreach ($row as $item) {
   $Sum += $item['Suggested']; // or else index
}
echo $Sum;
于 2012-12-24T21:15:11.217 回答
4
$sum = array_sum(
              array_map(function($item) { return $item["Suggested"]; }, $items)
       );
于 2012-12-24T21:14:59.517 回答
0

鉴于array_column可能会在 PHP 5.5 中出现的功能:

function array_column($input, $key) {
    if (is_array($key) || !is_array($input)) return array();
    $array = array();
    foreach($input as $v) {
        if(array_key_exists($key, $v)) $array[]=$v[$key];
    }
    return $array;
}

(来源:php.net)

你可以使用这个:

$sum = array_sum(array_column($items, 'Suggested'));

当然,这有点矫枉过正,我只想指出,这也是实现它的一种方式。

于 2012-12-24T21:20:23.423 回答
0

遍历数组的另一种方法是使用 for 循环,假设它是 $arr:

<?php    
function getSumOfKey($arr, $key){
     $sum = 0;
     for ($i = 0; $i < count($arr); $i++){
      (is_numeric($arr[$i][$key]))? $sum += $arr[$i][$key] : continue;
     }
     return $sum;
    } 
?>

要实现它:

echo 'The sum is: '.getSumOfKey($arr, 'Suggested');
于 2012-12-25T19:08:25.943 回答