本文实例讲述了php自定义排序uasort函数。分享给大家供大家参考,具体如下:项目需要风险
本文实例讲述了php自定义排序uasort函数。分享给大家供大家参考,具体如下:
项目需要风险排序,按 I(安全)<L(低风险)<M(中风险)<H(高风险) 的级别来排序
由于H排在I的前面,所以不能直接用sort来排序,要自定义。
用uasort()函数来自定义排序:
/*
* 二维数组按指定键值排须
*/
function arr_sort($array,$key,$order="asc"){//asc是升序 desc是降序//按 I<L<M<H 排序
$arr_nums=$arr=array();
foreach($array as $k=>$v){
$arr_nums[$k]=$v[$key];
}
if($order=='asc'){
uasort($arr_nums,'my_sort_asc');
}else{
uasort($arr_nums,'my_sort_desc');
}
foreach($arr_nums as $k=>$v){
$arr[$k]=$array[$k];
}
return $arr;
}
function my_sort_desc($a,$b){
if($a==$b) return 0;
if($a=='I' && $b!='I') return 1;
if($a=='L' && $b!='I') return 1;
if($a=='L' && $b=='I') return -1;
if($a=='M' && $b!='H') return -1;
if($a=='M' && $b=='H') return 1;
if($a=='H' && $b!='H') return -1;
}
function my_sort_asc($a,$b){
if($a==$b) return 0;
if($a=='I' && $b!='I') return -1;
if($a=='L' && $b!='I') return -1;
if($a=='L' && $b=='I') return 1;
if($a=='M' && $b!='H') return 1;
if($a=='M' && $b=='H') return -1;
if($a=='H' && $b!='H') return 1;
}
PS:这里再为大家推荐一款关于排序的演示工具供大家参考:
在线动画演示插入/选择/冒泡/归并/希尔/快速排序算法过程工具: http://tools.jb51.net/aideddesign/paixu_ys
php 自定义 uasort函数 二维数组 指定键值 排序