php怎么对一个数组的某一列求和
在PHP中,对一个数组的某一列求和是一个常见的需求。如果该数组是一个一维数组,使用array_sum()函数即可实现。例如:
$array = array(1, 2, 3, 4, 5); $sum = array_sum($array); // $sum = 15登录后复制
但如果该数组是一个二维数组,则需要先提取出该列的所有值,再将它们求和。可以使用array_column()函数提取某一列的值,然后再使用array_sum()函数对这些值进行求和。例如:
$records = array( array('name' => 'John', 'score' => 85), array('name' => 'Mary', 'score' => 92), array('name' => 'Peter', 'score' => 78), array('name' => 'Lisa', 'score' => 89) ); $scores = array_column($records, 'score'); $sum = array_sum($scores); // $sum = 344登录后复制
在上面的例子中,$records是一个二维数组,包含了每个人的姓名和分数。使用array_column()函数提取出所有的分数,然后使用array_sum()函数对它们进行求和,得到了总分数344。
需要注意的是,如果该列的值中包含了非数字类型(例如字符串),则需要先通过类型转换将它们转换成数字。否则,求和的结果可能会不准确。例如:
$records = array( array('name' => 'John', 'score' => '85'), array('name' => 'Mary', 'score' => '92'), array('name' => 'Peter', 'score' => '78'), array('name' => 'Lisa', 'score' => '89') ); $scores = array_column($records, 'score'); $sum = array_sum($scores); // $sum = 0登录后复制
在上面的例子中,$records中的分数都是字符串类型。如果直接对它们进行求和,会得到一个不准确的结果0。可以通过在array_column()函数中指定第三个参数将它们转换成数字类型。例如:
$records = array( array('name' => 'John', 'score' => '85'), array('name' => 'Mary', 'score' => '92'), array('name' => 'Peter', 'score' => '78'), array('name' => 'Lisa', 'score' => '89') ); $scores = array_column($records, 'score', 'name'); $scores = array_map('intval', $scores); $sum = array_sum($scores); // $sum = 344登录后复制
在上面的例子中,使用array_column()函数提取出了每个人的分数,并将它们存储在一个以姓名为键、分数为值的新数组中。然后使用array_map()函数对这些值进行类型转换,最终再使用array_sum()函数对它们进行求和,得到了正确的结果344。
综上所述,对一个数组的某一列求和在PHP中并不困难,只需要注意数据类型的问题即可。
以上就是php怎么对一个数组的某一列求和的详细内容,更多请关注海外IDC网其它相关文章!
【文章由高防cdn http://www.juniucdn.com处的文章,转载请说明出处】