二维数组根据第二维数组的某个元素进行排序,可以使用php内置函数:array_multisort()
函数返回排序数组。您可以输入一个或多个数组。函数先对第一个数组进行排序,接着是其他数组,如果两个或多个值相同,它将对下一个数组进行排序。
语法如下:
array_multisort(array1,sorting order,sorting type,array2,array3...)
参数 | 描述 |
---|---|
array1 | 必需。规定数组。 |
sorting order | 可选。规定排列顺序。可能的值: SORT_ASC - 默认。按升序排列 (A-Z)。 SORT_DESC - 按降序排列 (Z-A)。 |
sorting type | 可选。规定排序类型。可能的值: SORT_REGULAR - 默认。把每一项按常规顺序排列(Standard ASCII,不改变类型)。 SORT_NUMERIC - 把每一项作为数字来处理。 SORT_STRING - 把每一项作为字符串来处理。 SORT_LOCALE_STRING - 把每一项作为字符串来处理,基于当前区域设置(可通过 setlocale() 进行更改)。 SORT_NATURAL - 把每一项作为字符串来处理,使用类似 natsort() 的自然排序。 SORT_FLAG_CASE - 可以结合(按位或)SORT_STRING 或 SORT_NATURAL 对字符串进行排序,不区分大小写。 |
array2 | 可选。规定数组。 |
array3 | 可选。规定数组。 |
具体代码实例:
<?php
$arr = [
[ 'age' => '10',
'name' => 'zhangs'],
[ 'age' => '11',
'name' => 'lis'],
[ 'age' => '9',
'name' => 'wangw'],
[ 'age' => '30',
'name' => 'zhaol'],
];
// 根据age排序
$ages = array_column($arr, 'age');
array_multisort($ages, SORT_DESC, $arr);
参考地址:https://www.cnblogs.com/niuben/p/11192709.html
https://www.cnblogs.com/wenzheshen/p/9455554.html