使用內(nèi)置函數(shù)解決PHP多維數(shù)組排序問(wèn)題
學(xué)習(xí)PHP時(shí),你可能會(huì)遇到PHP多維數(shù)組排序問(wèn)題,這里將介紹PHP多維數(shù)組排序問(wèn)題的解決方法,在這里拿出來(lái)和大家分享一下,希望對(duì)大家有幫助。
#T#根據(jù)數(shù)組的鍵進(jìn)行比較大小,排序,就不用說(shuō)了,php有很多,很方便的內(nèi)置函數(shù),krsort(),ksort()等如果是根據(jù)數(shù)組的值進(jìn)行比較大小就麻煩一些。如果值沒(méi)有重復(fù)的情況,可以先用array_flip()交換鍵、值;然后krsort(),然后在array_flip()交換回來(lái),就可以比較大小。有值重復(fù)的情況,就要用到一些排序算法了,不過(guò)php有很方便的回調(diào)函數(shù)uasort()會(huì)保持原來(lái)的索引、usort()會(huì)重建索引。PHP多維數(shù)組排序代碼:
- php
- functioncmp($a,$b){
- if($a[”nums”]==$b[”nums”]){
- return0;
- }
- return($a[”nums”]<$b[”nums”])?-1:1;
- }
- $arr=Array(
- 0=>Array(
- “username”=>owen,
- “nums”=>2,
- ),
- 1=>Array(
- “username”=>d5s,
- “nums”=>5,
- ),
- 2=>Array(
- “username”=>pt,
- “nums”=>3,
- ),
- );
- uasort($arr,“cmp”);
- echo‘<prestyleprestyle=”text-align:left”>’;
- print_r($arr);
- echo‘< SPAN>pre>’;
- ?>
- Array
- (
- [0]=>Array
- (
- [username]=>owen
- [nums]=>2
- )
- [2]=>Array
- (
- [username]=>pt
- [nums]=>3
- )
- [1]=>Array
- (
- [username]=>d5s
- [nums]=>5
- )
- )