
本文介绍如何使用 PHP 的 usort() 配合 array_column() 和 max(),对嵌套多维数组中每个子项的 'sizes' 内层数组按 'weight' 值进行整体排序(以各 sizes 中的最大 weight 为排序依据),支持升序与降序。
本文介绍如何使用 PHP 的 usort() 配合 array_column() 和 max(),对嵌套多维数组中每个子项的 'sizes' 内层数组按 'weight' 值进行整体排序(以各 sizes 中的最大 weight 为排序依据),支持升序与降序。
在实际开发中,常需对结构复杂的多维数组进行“基于内层字段”的排序。例如,给定一个包含多个商品变体(sizes)的数组,每个商品可能有多个尺寸规格(含 weight、height),而我们需要按该商品所有规格中的最高(或最低)weight 值来排序整个商品条目——这无法通过 array_multisort() 直接实现,因其不支持动态提取嵌套极值。
此时,usort() 是更灵活、更推荐的解决方案。核心思路是:对每个外层数组元素 $a 和 $b,分别提取其 'sizes' 子数组中所有 'weight' 值,再取最大值(max(array_column(...))),最后用太空船操作符 <=> 比较这两个极值。
✅ 降序排序(最高 weight 在前)
usort($array, function($a, $b) {
return max(array_column($b['sizes'], 'weight'))
<=> max(array_column($a['sizes'], 'weight'));
});✅ 升序排序(最低 weight 在前)
只需交换 $a 与 $b 的位置(或乘以 -1),推荐写法如下:
usort($array, function($a, $b) {
return max(array_column($a['sizes'], 'weight'))
<=> max(array_column($b['sizes'], 'weight'));
});⚠️ 注意事项:
- array_column($arr, 'weight') 要求 $arr 是索引数组(如示例中的 sizes),若 sizes 为关联键名(如 's1' => [...]),需先 array_values() 转换;
- 若某 sizes 为空数组,max([]) 将触发警告并返回 false,建议增加防御性判断:
$aMax = !empty($a['sizes']) ? max(array_column($a['sizes'], 'weight')) : 0; $bMax = !empty($b['sizes']) ? max(array_column($b['sizes'], 'weight')) : 0; return $aMax <=> $bMax; // 升序- 此方法时间复杂度为 O(n×m),其中 n 为外层数组长度,m 为各 sizes 平均长度,适用于中等规模数据;超大规模建议预计算并缓存 max_weight 字段。
通过该方案,原始数据将按各商品所含规格的 最高 weight 值 重新排列,完全匹配预期输出:weight:80 所在的商品排第一(降序),weight:20 所在的商品排第一(升序)。简洁、可读、符合现代 PHP 编程实践。