php数组多个字段排序,PHP多维数组指定多字段排序及优先级

本文介绍了两个PHP函数,arraySort用于单字段排序,适用于升序或降序;sortArrByManyField则处理二维数组,根据多个字段设置优先级进行排序。通过实例演示了如何根据日期和评分优先级对数据进行定制排序。
摘要由CSDN通过智能技术生成

1,单个字段排序

public function arraySort($data,$key,$sort="desc"){

$last_names = array_column($data,$key);

if($sort=="desc")

array_multisort($last_names,SORT_DESC,$data);

else

array_multisort($last_names,SORT_ASC,$data);

return $data;

}

2 二维数组多个字段排序,设置优先级

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 = [

0=>[

"id"=>1,

"d"=>"2019-12-06 11:15-11:45",

"r"=>11

],

2=>[

"id"=>1,

"d"=>"2020-01-03 09:00-09:30",

"r"=>13

],

3=>[

"id"=>1,

"d"=>"2020-01-03 09:00-09:30",

"r"=>14

],

];

$arr = sortArrByManyField($arr,'d',SORT_ASC,'r',SORT_DESC);

print_r($arr);

Array

(

[0] => Array

(

[id] => 1

[d] => 2019-12-06 11:15-11:45

[r] => 11

)

[1] => Array

(

[id] => 1

[d] => 2020-01-03 09:00-09:30

[r] => 14

)

[2] => Array

(

[id] => 1

[d] => 2020-01-03 09:00-09:30

[r] => 13

)

)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值