php数组求平均分最直接方法是array_sum()除以count(),需防范空数组除零警告,接收表单数据时须用name="scores[]"确保为数组,并用is_array()和!empty()校验。

PHP 数组求平均分用 array_sum() + count() 最直接
算平均分本质就是「总分 ÷ 人数」,PHP 里没现成的 array_average(),但两步搞定:先用 array_sum() 加总,再用 count() 算个数。注意空数组会除零——count() 返回 0 时直接除会报 Warning,得兜底。
- 成绩存成索引数组最省事,比如
$scores = [85, 92, 78, 96] - 别用
foreach手动累加,除非你要跳过非数字项或做清洗 - 如果成绩是字符串数字(如
"85"),array_sum()会自动转,但含字母的(如"85分")会被当 0,得提前过滤
遇到 Warning: Division by zero 怎么办
这错误几乎都来自空数组:学生还没交卷、查数据库没结果、或者 $_POST['scores'] 根本没传过来。不能靠静默忽略,得主动判断。
- 检查前先用
is_array()和!empty()双重确认:if (is_array($scores) && !empty($scores)) { ... } - 别只写
if ($scores),空数组在条件里是 false,但非空数组里有 0 分也会被误判为 false - 数据库查出来是
null或false时,count()会返回 1(因为把整个null当一个元素),必须先?? []默认为空数组
带权重的成绩怎么算(比如平时 30% + 期末 70%)
纯平均分只是等权计算,实际教学常要加权。核心是把每个成绩乘对应权重,再求和——不是先平均再乘权重。
- 结构建议用关联数组:
$weighted_scores = ['homework' => ['score' => 88, 'weight' => 0.3], 'final' => ['score' => 94, 'weight' => 0.7]] - 手动循环算加权和:
$total = 0; foreach ($weighted_scores as $item) { $total += $item['score'] * $item['weight']; } - 别用
array_sum(array_column(...))套娃,可读性差,还容易漏乘权重 - 权重总和不等于 1?那就得归一化,否则结果失真;但一般业务场景下,前端或录入环节就该校验权重和是否为 1
从表单接收成绩时,$_POST['scores'] 是字符串还是数组
很多人卡在这儿:HTML 表单里多个同名 input,PHP 默认只收最后一个值,除非你显式声明为数组。这是最隐蔽的“算不对”源头。
立即学习“PHP免费学习笔记(深入)”;
- 前端必须写成
<input name="scores[]">,带方括号,PHP 才解析成数组 - 如果写成
name="scores",$_POST['scores']就是字符串(最后那个值),count()返回 1,array_sum()把字符串当字符数组拆开加——比如"85"会算成8+5=13 - 用
var_dump($_POST['scores'])看一眼类型,比猜快十倍 - 接收到后立刻用
array_filter($scores, 'is_numeric')清掉空值或非数字项,避免array_sum()把空字符串当 0 算进去
算平均分本身简单,难的是数据进来那一刻有没有变形、空、错类型——这些地方不盯紧,后面怎么调公式都没用。











