在 php 编程中,数组是一种非常常用的数据类型,可以用来存储一系列数据,而对于数组中的一列数据求和常常是需要的操作之一。下面我们就来介绍 php 中如何对数组某列求和。
在 PHP 中,可以使用 array_sum() 函数来对数组中的所有元素求和,该函数接受一个数组作为参数,并返回数组中所有元素的总和。例如:
$numbers = array(1, 2, 3, 4, 5); $sum = array_sum($numbers); echo "数组元素总和为:$sum";
以上代码将输出:
数组元素总和为:15
但是,如果我们需要对数组中的某一列数据求和呢?PHP 并没有内置的函数来直接实现这个功能,我们需要自己编写代码实现。
例如,我们有一个二维数组 $data,其中包含若干行数据,每一行数据都具有相同的数据结构,如下所示:
立即学习“PHP免费学习笔记(深入)”;
$data = array(
array('id' => 1, 'name' => 'Tom', 'score' => 80),
array('id' => 2, 'name' => 'Jack', 'score' => 90),
array('id' => 3, 'name' => 'Mary', 'score' => 85),
);现在,我们需要对 $data 数组中的 'score' 列数据求和,可以按照以下步骤实现:
- 定义一个变量 $sum,并初始化为 0,用于保存求和结果:
$sum = 0;
- 遍历数组 $data,依次取出每一行数据,并将该行数据中 'score' 列的值累加到 $sum 变量中:
foreach ($data as $row) {
$sum += $row['score'];
}- 最后,$sum 变量中保存的就是 'score' 列数据的总和。
完整代码如下:
$data = array(
array('id' => 1, 'name' => 'Tom', 'score' => 80),
array('id' => 2, 'name' => 'Jack', 'score' => 90),
array('id' => 3, 'name' => 'Mary', 'score' => 85),
);
$sum = 0;
foreach ($data as $row) {
$sum += $row['score'];
}
echo "score 列数据总和为:$sum";以上代码将输出:
score 列数据总和为:255
上述算法的时间复杂度为 O(n),其中 n 表示数组 $data 的行数,是一种比较高效的求和方法。
除了上述方法外,还可以使用 array_column() 函数来获取数组中某列数据,然后再使用 array_sum() 函数对该列数据求和。例如:
$data = array(
array('id' => 1, 'name' => 'Tom', 'score' => 80),
array('id' => 2, 'name' => 'Jack', 'score' => 90),
array('id' => 3, 'name' => 'Mary', 'score' => 85),
);
$scores = array_column($data, 'score');
$sum = array_sum($scores);
echo "score 列数据总和为:$sum";以上代码将输出:
score 列数据总和为:255
使用 array_column() 函数获取数组中某列数据的优点在于可以灵活地选择需要获取的列,也可以配合其他数组函数来进行更复杂的操作。
综上所述,PHP 中对数组某列求和可以通过遍历数组并累加该列数据的方法来实现,也可以使用 array_column() 函数先获取该列数据,再使用 array_sum() 函数来求和。要根据具体情况选择最适合的方法。











