php自定義排序uasort函數(shù)示例【二維數(shù)組按指定鍵值排序】
本文實例講述了php自定義排序uasort函數(shù)。分享給大家供大家參考,具體如下:
項目需要風險排序,按 I(安全)<L(低風險)<M(中風險)<H(高風險) 的級別來排序
由于H排在I的前面,所以不能直接用sort來排序,要自定義。
用uasort()函數(shù)來自定義排序:
/*
* 二維數(shù)組按指定鍵值排須
*/
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:這里再為大家推薦一款關(guān)于排序的演示工具供大家參考:
在線動畫演示插入/選擇/冒泡/歸并/希爾/快速排序算法過程工具:
http://tools.jb51.net/aideddesign/paixu_ys
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)組(Array)操作技巧大全》、《php排序算法總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設計算法總結(jié)》、《php字符串(string)用法總結(jié)》及《PHP常用遍歷算法與技巧總結(jié)》
希望本文所述對大家PHP程序設計有所幫助。
相關(guān)文章
PHP中根據(jù)IP地址判斷城市實現(xiàn)城市切換或跳轉(zhuǎn)代碼
先要獲取ip地址相當簡單,下面先介紹兩種獲取IP地址的代碼,后面需要利用QQIP庫來查找當前IP是屬于那個IP段然后得出城市字段并返回2012-09-09
PHPExcel中文幫助手冊|PHPExcel使用方法(分享)
下面小編就為的帶來一篇PHPExcel中文幫助手冊|PHPExcel使用方法(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-06-06
PHP采用自定義函數(shù)實現(xiàn)遍歷目錄下所有文件的方法
這篇文章主要介紹了PHP采用自定義函數(shù)實現(xiàn)遍歷目錄下所有文件的方法,是PHP程序開發(fā)中常見的功能,需要的朋友可以參考下2014-08-08
《Head First 設計模式》代碼之PHP版(面向?qū)ο髮W習)
《Head First 設計模式》是本不錯的講解設計模式的書,不像F4寫的那么枯燥,應該算是比較容易理解的好書。2010-06-06

