[英]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 中处理自定义模块,需要总结 [value],但是我尝试了使用 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 个具有索引“值”的数组的数组,您只需要使用嵌套的 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
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.