牛骨文教育服务平台(让学习变的简单)
博文笔记

PHP多维数组指定多字段排序

创建时间:2016-10-14 投稿人: 浏览次数:8220

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(empty($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)
      }
    }
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。