我們知道在php數(shù)組中分為多維數(shù)組與一維數(shù)組,我們下面來分別講述一下php多維數(shù)組與一維數(shù)組排序原理與實(shí)現(xiàn)方法吧。
一維數(shù)組
第一組:sort 和 rsort,按照PHP數(shù)組鍵值的順序asc和逆序desc進(jìn)行排序,同時(shí)破壞原來數(shù)組的索引關(guān)系——其實(shí)是刪除索引之后重新建立從0開始的數(shù)字索引,看一下例程,代碼如下:
- <?php
- $a = array("a"=>1,2);
- sort($a);
- var_dump($a);
- rsort($a);
- var_dump($a);
- ?>
看一下第一個(gè)輸出結(jié)果,第一個(gè)輸出:
- array(2) {
- [0]=>
- int(1)
- [1]=>
- int(2)
- }
第二個(gè)輸出:
- array(2) {
- [0]=>
- int(5)
- [1]=>
- int(4)
- }
發(fā)現(xiàn)沒有我們?cè)瓉矶x的索引a哪里去了?哪里去了?可以肯定的說是被他們無情的刪除了,你要是對(duì)原來的索引關(guān)系并不在意的話,可以使用他們!
第二組函數(shù):asort 和 arsort,這兩個(gè)函數(shù)就比較厲害一點(diǎn)了,只要他們可以保留數(shù)組原有的索引關(guān)系,把上例的sort 和 rsort 分別用這兩個(gè)函數(shù)替換一下,看運(yùn)行結(jié)果代碼如下:
- array(2) {
- ["a"]=>
- int(1)
- [0]=>
- int(2)
- }
- array(2) {
- [0]=>
- int(2)
- ["a"]=>
- int(1)
- }
這個(gè)一看就明白的,不用說了吧!
第三組PHP數(shù)組排序函數(shù):krsort 和 ksort 這兩個(gè)不同于以上兩組,這兩函數(shù)是對(duì)鍵名進(jìn)行排序的,大家可以把上例的函數(shù)替換成這兩個(gè),看看具體運(yùn)行結(jié)果,這里也不說了,不然這個(gè)文章寫的就太長(zhǎng)了,怕有些兄弟沒有耐心看到本文的重點(diǎn),雖然重點(diǎn)就在下邊!
通過自定義函數(shù)對(duì)PHP數(shù)組進(jìn)行排序,有三個(gè)函數(shù)分別是:
uasort 通過自定義函數(shù)對(duì)PHP數(shù)組的鍵值進(jìn)行排序,并且保留原來的索引關(guān)系。
uksort 通過自定義函數(shù)對(duì)PHP數(shù)組的鍵名進(jìn)行排序,并且保留原來的索引關(guān)系。
usort通過自定義函數(shù)對(duì)PHP數(shù)組的鍵值進(jìn)行排序,并且刪除原來的索引關(guān)系,從零開始建立新的索引。
這個(gè)地方當(dāng)然需要一個(gè)例子,代碼如下:
- <!--p
- //首先頂一個(gè)函數(shù),這個(gè)函數(shù)需要接受兩個(gè)參數(shù),并且返回值是一定的
- //第一個(gè)參數(shù)等于第二個(gè)參數(shù)的時(shí)候返回0,小于的時(shí)候返回-1,大于返回1
- function cmp($a,$b){
- $a+=1;
- $b+=3;//改變這些值之后進(jìn)行比較
- if($a==$b) return 0;
- return ($a<$b)?-1:1;
- }
- $a =array(1,4,3,5);
- uasort($a,'cmp');
- var_dump($a);
- -->
- //輸出結(jié)果:
- array(4) {
- [0]=>
- int(1)
- [3]=>
- int(5)
- [1]=>
- int(4)
- [2]=>
- int(3)
- }
多維數(shù)組的排序
例如array_multisort($a,$b),$a,$b是兩個(gè)數(shù)組,如果排序之后,$a數(shù)組的第3個(gè)元素被排到了第一位,那么$b的第三個(gè)元素不管他在$b中的大小都會(huì)排在第一位,看看下邊的程序運(yùn)行結(jié)果,代碼如下:
- <?php
- $a =array(100,80,50,10,0);
- $b = array("c","f","q","e","z");
- array_multisort($a,$b);
- var_dump($a);
- var_dump($b);
- ?>
- //運(yùn)行結(jié)果:
- array(5) { [0]=> int(0) [1]=> int(10) [2]=> int(50) [3]=> int(80) [4]=> int(100) }
- array(5) { [0]=> string(1) “z” [1]=> string(1) “e” [2]=> string(1) “q” [3]=> string(1) “f” [4]=> string(1) “c” }
很顯然本來是數(shù)組b第五個(gè)元素的z被排到了第一位!
其實(shí)說明白了就是,array_multisort()先把第一個(gè)數(shù)組按照鍵值的大小排序,然后其它數(shù)組都按照第一個(gè)數(shù)組的調(diào)整策略進(jìn)行調(diào)整——第三個(gè)元素放到第一位,第二個(gè)元素放到第二位……——其實(shí)這個(gè)多維數(shù)組排序算法的最基本體現(xiàn)!
不過需要注意的是:兩個(gè)數(shù)組的元素個(gè)數(shù)必須相同,不然就會(huì)出現(xiàn)一個(gè)警告信息:
Warning: array_multisort() [function.array-multisort]: Array sizes are inconsistent in ……
好了,希望上邊的大家也能用上,咱們還是說主要的吧:array_multisort()對(duì)多維數(shù)組進(jìn)行排序,這個(gè)功能將來做項(xiàng)目的時(shí)候是非常有用的!
首先我們看看對(duì)多維數(shù)組的每一元素[數(shù)組]進(jìn)行排序的操作方法,很簡(jiǎn)單,但是有幾個(gè)參數(shù)需要說明一下,如果您對(duì)sql有所了解一看估計(jì)就明白了,代碼如下:
- <?php
- //讓我們來構(gòu)造一個(gè)多維數(shù)組
- $a=array(100,2,4,7,7);
- $b=array('ab','ac','ad','ag','ap');
- $ab = array($a,$b);
- //開始排序
- array_multisort($ab[0],SORT_NUMERIC,SORT_DESC,$ab[1],SORT_STRING,SORT_ASC);
- print_r($ab);
- ?>
說明一下:首先我們用SORT_NUMERIC來聲明對(duì)$ab[0]用數(shù)字類型排序,用SORT_DESC聲明順序是逆序(從大到小),然后我們對(duì)$ab[1]用字符串類型排序,順序是升序(順序)最后數(shù)組$ab的排序結(jié)果是兩者的結(jié)合,先按$ab[0]的逆序,如果$ab[0]中存在大小相同的數(shù)值則按照$ab[1]的順序排列,輸出結(jié)果如下:
- Array (
- [0] => Array ( [0] => 100 [1] => 7 [2] => 7 [3] => 4 [4] => 2 )
- [1] => Array ( [0] => ab [1] => ag [2] => ap [3] => ad [4] => ac )
- )
是不是很像在數(shù)據(jù)庫(kù)中用order by?其實(shí)真的差不多!現(xiàn)在我們?cè)倏匆粋€(gè)更加貼近實(shí)際應(yīng)用的例子,代碼如下:
- <?php
- $array[] = array("age"=>20,"name"=>"li");
- $array[] = array("age"=>21,"name"=>"ai");
- $array[] = array("age"=>20,"name"=>"ci");
- $array[] = array("age"=>22,"name"=>"di");
- foreach ($array as $key=>$value){
- $age[$key] = $value['age'];
- $name[$key] = $value['name'];
- }
- array_multisort($age,SORT_NUMERIC,SORT_DESC,$name,SORT_STRING,SORT_ASC,$array);
- print_r($array);
- ?>
這個(gè)例子的$array[]數(shù)組,是按照數(shù)據(jù)庫(kù)中讀出的記錄來構(gòu)造的,我們現(xiàn)在對(duì)他們按照年齡從大到小的順序排列,如果年齡相同就按照名字的順序排序,這樣的排序才是我們將來會(huì)經(jīng)常用的到的,因?yàn)閍rray_multisort()需要的排序參數(shù)必須是一個(gè)列,所以我們用foreach把這個(gè)數(shù)組的年齡和姓名讀出來,之后呢?
就像上邊的例子一樣,進(jìn)行排序,最后一個(gè)參數(shù)$array想必大家也看見了,是的這里需要聲明對(duì)哪個(gè)數(shù)組進(jìn)行排序,因?yàn)槲覀兦斑厓蓚€(gè)參數(shù)在形式上已經(jīng)和需要排序的PHP數(shù)組沒有關(guān)系了,雖然其實(shí)他們就是$array中的數(shù)據(jù)——我們從$array中抽取的列——排序當(dāng)然是需要列,還沒見過用行數(shù)據(jù)進(jìn)行排序的呢!
輸出結(jié)果如下—正如我們所想的,代碼如下:
- Array (
- [0] => Array ( [age] => 22 [name] => di )
- [1] => Array ( [age] => 21 [name] => ai )
- [2] => Array ( [age] => 20 [name] => ci )
- [3] => Array ( [age] => 20 [name] => li )
- )
看到了吧,其實(shí)也很簡(jiǎn)單,就是那幾個(gè)需要大寫的參數(shù)有點(diǎn)煩人而已!雖說也有點(diǎn)難以理解,但是理解了就好了,將來很有用的哦!
附錄:排序順序標(biāo)志:
SORT_ASC – 按照上升順序排序
SORT_DESC – 按照下降順序排序
排序類型標(biāo)志:
SORT_REGULAR – 將項(xiàng)目按照通常方法比較
SORT_NUMERIC – 將項(xiàng)目按照數(shù)值比較
SORT_STRING – 將項(xiàng)目按照字符串比較
新聞熱點(diǎn)
疑難解答