繁体   English   中英

PHP:从数组中的“行”中获取所有值

[英]PHP: Get all values from an "row" in an array

我想知道如何获取数组特定“行”中所有值的总和。

例如,我得到了这个数组:

[0] {array( "date" => "2015-01-01", "value" => 5) }
[1] {array( "date" => "2015-01-02", "value" => -3) }
...

现在我想得到这个数组中所有“值”的总和 - 在这种情况下它将是 2。

我怎样才能在 PHP 中做到这一点?

我会说array_column适合这种描述,不是吗?

$values = array_column($array, 'value');
var_dump($values);

恰当命名的array_sum将很好地完成这一切

$sum = array_sum($values);

如果您仍然使用 PHP5.4(直到 5.5 才引入array_column ):

$sum = 0;
foreach ($array as $sub)
{
    $sum += $sub['value'];
}

会做的很好。 无论如何,它可能会胜过array_column + array_sum方法(因为它不是调用函数,而是依赖于语言结构)

有一个特定的函数: array_reduce

<?php
$array = array(array('date'=>'', value=>5),array('date'=>'', value=>-3));

$t = array_reduce($array, function($result, $item){
    $result['value'] = $result['value'] + $item['value']; 
    return $result;
}, array('value'=>0));

array reduce 获取一个数组,一个要在该数组上使用的函数,第三个参数是您在第一次调用该函数时使用的初始数组。

我在这里使用了一个数组,因此您可以根据需要对日期(最大值或最小值)进行一些处理。 你当然可以只使用一个int。 然后它看起来更简单:

$t = array_reduce($array, function($result, $item){
    $result = $result + $item['value']; 
    return $result;
}, 0);

您可以使用array_sum()array_map()的组合来实现这一点,如下所示:

$sum = array_sum(
    array_column(
        $originalArray,
        'value'
    )
);

如果您使用的是旧版本的 PHP (< 5.5.0),那么您可以使用以下内容:

$sum = array_sum(
    array_map(
        function($arr) {
            return $arr['value'];
        },
        $originalArray
    )
);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM