php自义定对二维数组进行排序

概述:

当我们处理数据的时候,经常会遇到对数据的排序,当然如果是直接用数据库读出数据,直接用order by 会非常方便,但是有时我们会遇到固定的数据而不是直接读数据库的情况。那么我们需要一个方法去对二维数组进行排序。

准备:

在开始之前,我们先来了解一下PHP自带的对多个数组或多维数组进行排序的函数:
array_multisort(array1,sorting order, sorting type,array2,array3..)

array1 必选。规定输入的数组。
sorting order 可选。规定排列顺序。可能的值是 SORT_ASC 和 SORT_DESC。
sorting type 可选。规定排序类型。可能的值是SORT_REGULAR、SORT_NUMERIC和SORT_STRING。
array2 可选。规定输入的数组。
array3 可选。规定输入的数组。

第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话,就会按照下一个输入数组中相应值的大小进行排序,依此类推。

第一个参数是数组,随后的每一个参数可能是数组,也可能是下面的排序顺序标志(排序标志用于更改默认的排列顺序)之一:

SORT_ASC - 默认,按升序排列。(A-Z)
SORT_DESC - 按降序排列。(Z-A)

随后可以指定排序的类型:

SORT_REGULAR - 默认。将每一项按常规顺序排列。 SORT_NUMERIC - 将每一项按数字顺序排列。 SORT_STRING
- 将每一项按字母顺序排列

分析:

主要代码:

public function  test(){
        $coupon_codes =array_keys( $this->coupon_pool['egg_prize']);
        array_push($coupon_codes,$this->coupon_pool['share'][0]);
        $coupons = $this->coupon_model->get_by_codes($coupon_codes);
        foreach($coupons as $coupon ){
            // 有抽奖记录时返回已获得奖品
            $data[] = array(
                'show_name' => substr($coupon->show_name,0, -9),
                'kind' => substr($coupon->show_name, -9),
                'end_time' => $coupon->end_time,
                'instruction' => $coupon->instruction,
            );
        }
        var_dump($data);
        echo "</br>.111111111111111111111111111111111111111111"    ;
        //解决兑换券总出现在赠送上面
        $data = $this->my_sort($data,'kind',SORT_ASC,SORT_STRING);
        var_dump($data);


    }

    function  my_sort($arrays,$sort_key,$sort_order=SORT_ASC,$sort_type=SORT_NUMERIC ){
        if(is_array($arrays)){
            foreach ($arrays as $array){
                if(is_array($array)){
                    $key_arrays[] = $array[$sort_key];
                }else{
                    return false;
                }
            }
        }else{
            return false;
        }
        array_multisort($key_arrays,$sort_order,$sort_type,$arrays);
        return $arrays;
    }

返回的数据:



array(3) {
  [0]=>
  array(4) {
    ["show_name"]=>
    string(10) "100M流量"
    ["kind"]=>
    string(9) "兑换券"
    ["end_time"]=>
    string(19) "2016-07-31 00:00:00"
    ["instruction"]=>
    string(38) "兑换截止日期:2016年10月31日"
  }
  [1]=>
  array(4) {
    ["show_name"]=>
    string(12) "100M流量x5"
    ["kind"]=>
    string(9) "转赠券"
    ["end_time"]=>
    string(19) "2016-10-31 00:00:00"
    ["instruction"]=>
    string(27) "仅限转赠给好友使用"
  }
  [2]=>
  array(4) {
    ["show_name"]=>
    string(10) "200M流量"
    ["kind"]=>
    string(9) "兑换券"
    ["end_time"]=>
    string(19) "2016-07-31 00:00:00"
    ["instruction"]=>
    string(38) "兑换截止日期:2016年10月31日"
  }
}
<br>---------------------------------分割线------------------------------------------<br>array(3) {
  [0]=>
  array(4) {
    ["show_name"]=>
    string(10) "100M流量"
    ["kind"]=>
    string(9) "兑换券"
    ["end_time"]=>
    string(19) "2016-07-31 00:00:00"
    ["instruction"]=>
    string(38) "兑换截止日期:2016年10月31日"
  }
  [1]=>
  array(4) {
    ["show_name"]=>
    string(10) "200M流量"
    ["kind"]=>
    string(9) "兑换券"
    ["end_time"]=>
    string(19) "2016-07-31 00:00:00"
    ["instruction"]=>
    string(38) "兑换截止日期:2016年10月31日"
  }
  [2]=>
  array(4) {
    ["show_name"]=>
    string(12) "100M流量x5"
    ["kind"]=>
    string(9) "转赠券"
    ["end_time"]=>
    string(19) "2016-10-31 00:00:00"
    ["instruction"]=>
    string(27) "仅限转赠给好友使用"
  }
}

猜你喜欢

转载自blog.csdn.net/Tim_phper/article/details/52935955