概述:
当我们处理数据的时候,经常会遇到对数据的排序,当然如果是直接用数据库读出数据,直接用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) "仅限转赠给好友使用"
}
}