PHP多维数组指定多字段排序的示例代码
本篇文章主要介绍了PHP多维数组指定多字段排序的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧。
介绍array_multisort方法
array_multisort — 对多个数组或多维数组进行排序.其php 手册中的说明如下:
bool array_multisort ( array &$arr [, mixed $arg = SORT_ASC [, mixed $arg = SORT_REGULAR [, mixed $... ]]] )
参数
arr
要排序的一个 array。
arg
接下来的每个参数可以是另一个 array 或者是为之前 array 排序标志选项参数: SORT_ASC, SORT_DESC,SORT_REGULAR, SORT_NUMERIC, SORT_STRING.
…
Additional arg's.
先实现指定多维数组一个字段排序
此处要求根据其中的一个字段来对数组进行排序,数组假设如下:
- $array = array(
- 0=>array('id'=>8,'name'=>'Tom'),
- 1=>array('id'=>9,'name'=>'Peter'),
- 2=>array('id'=>5,'name'=>'Jack')
- );
我们要根据二维数组的id值来排序,转换后的数组格式如下:
- $array = array(
- 0=>array('id'=>5,'name'=>'Jack')
- 1=>array('id'=>8,'name'=>'Tom'),
- 2=>array('id'=>9,'name'=>'Peter')
- );
要完成上述的转换,需要用到上面介绍的array_multisort函数,如下:
- function sortArrByOneField(&$array, $field, $desc = false){
- $fieldArr = array();
- foreach ($array as $k => $v) {
- $fieldArr[$k] = $v[$field];
- }
- $sort = $desc == false ? SORT_ASC : SORT_DESC;
- array_multisort($fieldArr, $sort, $array);
- }
通过将待排序数组的各个数组的$field保存在一位数组fieldArr中,在传入array_multisort中参与排序。其中field数组的值如下:
array(0=>8,1=>9,2=>5)
传入 array_multisort后,相当于对$field一维数组的排序,而后根据排序后的key重新构建传入的待排序数组。
实现多维数组的指定多个字段排序
上面的实例讲解了如何实现多维数组指定一个字段排序,但如果要实现指定多个字段来对数组进行排序该如何思考?
多个字段是几个?2个,3个或更多,所以这个不确定的因素需要排除。
我们先来看2指定2个字段进行排序的方案:
- $arr = array(
- '0' => array(
- 'id' => 3,
- 'age' => 27
- ),
- '1' => array(
- 'id' => 5,
- 'age' => 50
- ),
- '2' => array(
- 'id' => 4,
- 'age' => 44
- ),
- '3' => array(
- 'id' => 3,
- 'age' => 78
- )
- );
- foreach ( $arr as $key => $row ){
- $id[$key] = $row ['id'];
- $age[$key] = $row ['age'];
- }
- array_multisort($id, SORT_ASC, $age, SORT_DESC, $arr);
- print_r($arr);
- //result:Array([0]=>Array(['id']=>3 ['age']=>78) [1]=>Array(['id']=>3 ['age']=>27) [2]=>Array(['id']=>4 ['age']=>44) [3]=>Array(['id']=>5 ['age']=>50))
重构上述代码,只要采用php中的func_get_args函数,来动态获取传入的值,既可以解决多字段个数不确定的问题。实现如下:
- $array1 = array(
- 0=>array('id'=>8,'name'=>'Apple','age'=> 18),
- 1=>array('id'=>8,'name'=>'Bed','age'=>17),
- 2=>array('id'=>5,'name'=>'Cos','age'=>16),
- 3=>array('id'=>5,'name'=>'Cos','age'=>14)
- );
- function sortArrByManyField(){
- $args = func_get_args();
- if(emptyempty($args)){
- return null;
- }
- $arr = array_shift($args);
- if(!is_array($arr)){
- throw new Exception("第一个参数不为数组");
- }
- foreach($args as $key => $field){
- if(is_string($field)){
- $temp = array();
- foreach($arr as $index=> $val){
- $temp[$index] = $val[$field];
- }
- $args[$key] = $temp;
- }
- }
- $args[] = &$arr;//引用值
- call_user_func_array('array_multisort',$args);
- return array_pop($args);
- }
- $arr = sortArrByManyField($array1,'id',SORT_ASC,'name',SORT_ASC,'age',SORT_DESC);
- print_r($arr);
运行结果如下:
- array(4) {
- [0]=>array(3) {
- ["id"]=>int(5)
- ["name"]=>string(3) "Cos"
- ["age"]=>int(16)
- }
- [1]=>array(3) {
- ["id"]=>int(5)
- ["name"]=>string(3) "Cos"
- ["age"]=>int(14)
- }
- [2]=>array(3) {
- ["id"]=>int(8)
- ["name"]=>string(5) "Apple"
- ["age"]=>int(18)
- }
- [3]=>array(3) {
- ["id"]=>int(8)
- ["name"]=>string(3) "Bed"
- ["age"]=>int(17)
- }
- }