数组的排序是我们经常会使用的到的,一维数组可以用一个简单的krsort() 函数进行升序排列,或者使用 arsort() 函数进行降序排列 。但是如何是多维数组那么情况就会复杂很多,没有可以直接实现多维数组按照某个键值进行排序的函数。
$data =[
['name'=>'张三','sex'=>'男','age'=>'66'],
['name'=>'潘某人SEO','sex'=>'男','age'=>'18'],
['name'=>'小红','sex'=>'女','age'=>'40'],
]
如上数组,我们如何按照年龄进行升序排列呢,基本的思路就是以键值“age”为基础进行升序。我们可以使用array_multisort()函数和array_column() 函数组合使用就可以达到这个效果。
array_multisort()函数
语法:array_column(array,column_key,index_key);
array---必需,规定要使用的多维数组
column_key---必需,需要返回值的列
index_key---可选。用作返回数组的索引/键的列。
可以实现的功能是返回输入数组中某个单一列的值。就拿上面的数组$data为列子,array_column($data,age)的结果如下所示。
$data =[ ‘age'=>'66', 'age'=>'18', 'age'=>'40' ]
array_multisort()函数
array_multisort()是数组排序函数,可以对多个PHP数组进行排序,排序结果是所有的数组都按第一个数组的顺序进行排列,多个数组排序的键与第一个排列好的数组对应。
语法: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等等---可选,规定数组。
多维数组排序:array_multisort(array_column($data,age),SORT_ASC,$data),运行结果如下:
$data =[ ['name'=>'潘某人SEO','sex'=>'男','age'=>'18'], ['name'=>'小红','sex'=>'女','age'=>'40'], ['name'=>'张三','sex'=>'男','age'=>'66'] ]
运行逻辑就是参数array1=array_column($data,age),SORT_ASC代表升序,会把array1数组进行一个升序排列,实际操作上就是把第一行数据放到最后一列;array_multisort()函数就会把SORT_ASC代表升序操作对array1所作的操作,同等的对待array2,array3等数组。
基于这个原理,所有规定数组必须和array1的元素个数必须相同,所以我们array1是通过array_column()对数组进行了降维打击,元素个数完全都是相同的,并且sex键值位置的顺序都是相同的,也就是说对简化后的一维数组进行升序就可以同步的对多维数组进行升序操作,妙不可言。