汇总数组值

Sum up the array values

Array
(
    [0] => Array( [0] => Array( [value] => 25 ) )
    [1] => Array( [0] => Array( [value] => 75 ) )
    [2] => Array( [0] => Array( [value] => 10 ) )
    [3] => Array( [0] => Array( [value] => 10 ) )
)

我正在 drupal 中开发自定义模块,需要总结 [值], 但是,我尝试了使用 array_column、array_sum 的不同方法,但没有得到解决方案。 任何帮助,将不胜感激。谢谢

代码

$contributionDetails = $node->get('field_contributions')->getValue();              
foreach ( $contributionDetails as $element ) {
    $p = Paragraph::load( $element['target_id'] );
    $text[] = $p->field_contribution_percentage->getValue();             
}

几个循环和一个累加器是实现此目的的一种方法

$tot = 0;
foreach ($array as $a){
    foreach ($a as $b){
        $tot += $b['value'];
    }
}
echo $tot;

或者如果您确定内部数组总是只会出现一次。

$tot = 0;
foreach ($array as $a){
    $tot += $a[0]['value'];
}
echo $tot;

或者使用您刚刚发布的代码

$contributionDetails = $node->get('field_contributions')->getValue();              
$tot = 0;
foreach ( $contributionDetails as $element ) {
    $p = Paragraph::load( $element['target_id'] );
    $text[] = $p->field_contribution_percentage->getValue();
    $tot += $p->field_contribution_percentage->getValue();
}
echo $tot;

所以你有一个包含 2 个索引为 'value' 的数组的数组,你只需要使用嵌套的 foreach 和一个变量 $sum 循环每个数组,该变量总结了每次迭代的值。

试试这个代码:

<?php 

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

echo $sum;

这将输出 120

您可以在此处使用 array_map 而不是累加器:

$arraySum = array_map(function ($v) {
  return reset($v)['value'];
}, $text);

print_r(array_sum($arraySum)); // 120

编辑,作为完整示例:

$values = [
    [['value' => 25]],
    [['value' => 75]],
    [['value' => 10]],
    [['value' => 10]],
];

echo array_sum(array_map(function ($v) {
  return reset($v)['value'];
}, $values)); // 120