php二维数组怎么把某一列相加_php二维数组列求和技巧【教程】

1次阅读

可通过四种方法对php二维数组某列求和:一、foreach循环累加;二、Array_column与array_sum组合;三、array_reduce配合匿名函数;四、for循环数字索引访问。

php二维数组怎么把某一列相加_php二维数组列求和技巧【教程】

如果您有一个PHP二维数组,需要对其中某一列的所有元素进行求和,则可以通过多种方式实现。以下是几种常用且有效的操作方法:

一、使用foreach循环遍历累加

该方法通过手动遍历二维数组的每一行,提取指定列的值并累加到一个变量中,适用于任意键名或索引结构的数组。

1、定义一个初始和变量,例如 $sum = 0;

2、使用 foreach 遍历二维数组,每轮获取当前子数组;

立即学习PHP免费学习笔记(深入)”;

3、从当前子数组中提取目标列的值,例如 $row[‘score’] 或 $row[1];

4、将该值加到 $sum 变量中;

5、循环结束后,$sum 即为该列总和。

二、使用array_column与array_sum组合

该方法利用PHP内置函数 array_column 提取指定列生成一维数组,再用 array_sum 直接求和,代码简洁且性能良好,要求PHP版本 ≥ 5.5.0。

1、调用 array_column($array, ‘price’) 提取键名为 ‘price’ 的列;

2、将上一步结果作为参数传入 array_sum();

3、返回值即为该列所有数值之和;

4、若列中存在非数值项,array_sum会自动忽略非数字类型(如字符串NULL)并视作0

三、使用array_reduce配合匿名函数

该方法借助 array_reduce 对二维数组逐行处理,在回调函数中持续累加目标列的值,灵活性高,适合需条件过滤或类型转换的场景。

1、定义匿名函数,接收累计值 $carry 和当前行 $item;

php二维数组怎么把某一列相加_php二维数组列求和技巧【教程】

图酷AI

下载即用!可以免费使用的AI图像处理工具,致力于为用户提供最先进的AI图像处理技术,让图像编辑变得简单高效。

php二维数组怎么把某一列相加_php二维数组列求和技巧【教程】 106

查看详情 php二维数组怎么把某一列相加_php二维数组列求和技巧【教程】

2、在函数体内提取 $item[‘amount’] 并加到 $carry 上;

3、调用 array_reduce($array, $callback, 0) 启动归约过程;

4、若某行缺失目标键,需提前判断 isset($item[‘amount’]),否则会触发Notice警告

四、使用for循环配合数字索引访问

当二维数组为纯数字索引且结构规整时,可用 for 循环按索引直接访问,避免键名查找开销,执行效率较高。

1、获取外层数组长度,例如 $len = count($data);

2、初始化 $sum = 0;

3、使用 for ($i = 0; $i

4、每次读取 $data[$i][2] 获取第3列(索引为2)的值;

5、必须确保每行都存在该索引,否则会报undefined offset错误

五、使用array_map与array_sum组合(带键名映射)

该方法先用 array_map 提取目标列构成新数组,再求和,适用于需对列值做简单预处理(如强制转int)的情况。

1、编写回调函数,例如 function($row) { return (int)$row[‘quantity’]; };

2、用 array_map 调用该函数处理整个二维数组;

3、将 map 结果传入 array_sum;

4、若原始值含单位字符(如”10kg”),(int)转换可自动截取前导数字

text=ZqhQzanResources