国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 語(yǔ)言 > PHP > 正文

php數(shù)組排序之多維數(shù)組與一維數(shù)組

2024-09-04 11:45:54
字體:
供稿:網(wǎng)友

我們知道在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ù)字索引,看一下例程,代碼如下:

  1. <?php 
  2. $a = array("a"=>1,2); 
  3. sort($a); 
  4. var_dump($a); 
  5.  
  6. rsort($a); 
  7. var_dump($a); 
  8. ?>  

看一下第一個(gè)輸出結(jié)果,第一個(gè)輸出:

  1. array(2) { 
  2.   [0]=> 
  3.   int(1) 
  4.   [1]=> 
  5.   int(2) 

第二個(gè)輸出:

  1. array(2) { 
  2.   [0]=> 
  3.   int(5) 
  4.   [1]=> 
  5.   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é)果代碼如下:

  1. array(2) { 
  2.   ["a"]=> 
  3.   int(1) 
  4.   [0]=> 
  5.   int(2) 
  6. array(2) { 
  7.   [0]=> 
  8.   int(2) 
  9.   ["a"]=> 
  10.   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è)例子,代碼如下:

  1. <!--p 
  2. //首先頂一個(gè)函數(shù),這個(gè)函數(shù)需要接受兩個(gè)參數(shù),并且返回值是一定的 
  3. //第一個(gè)參數(shù)等于第二個(gè)參數(shù)的時(shí)候返回0,小于的時(shí)候返回-1,大于返回1 
  4.  
  5. function cmp($a,$b){ 
  6.  $a+=1; 
  7.  $b+=3;//改變這些值之后進(jìn)行比較 
  8.  
  9.  if($a==$breturn 0; 
  10.  return ($a&lt;$b)?-1:1; 
  11.  
  12. $a =array(1,4,3,5); 
  13. uasort($a,'cmp'); 
  14. var_dump($a); 
  15. -->  
  16. //輸出結(jié)果: 
  17. array(4) { 
  18.   [0]=> 
  19.   int(1) 
  20.   [3]=> 
  21.   int(5) 
  22.   [1]=> 
  23.   int(4) 
  24.   [2]=> 
  25.   int(3) 

多維數(shù)組的排序

例如array_multisort($a,$b),$a,$b是兩個(gè)數(shù)組,如果排序之后,$a數(shù)組的第3個(gè)元素被排到了第一位,那么$b的第三個(gè)元素不管他在$b中的大小都會(huì)排在第一位,看看下邊的程序運(yùn)行結(jié)果,代碼如下:

  1. <?php  
  2. $a =array(100,80,50,10,0); 
  3. $b = array("c","f","q","e","z"); 
  4. array_multisort($a,$b); 
  5. var_dump($a); 
  6. var_dump($b); 
  7. ?>  
  8. //運(yùn)行結(jié)果: 
  9. array(5) { [0]=> int(0) [1]=> int(10) [2]=> int(50) [3]=> int(80) [4]=> int(100) } 
  10. 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ì)就明白了,代碼如下:

  1. <?php 
  2. //讓我們來構(gòu)造一個(gè)多維數(shù)組 
  3. $a=array(100,2,4,7,7); 
  4. $b=array('ab','ac','ad','ag','ap'); 
  5.  
  6. $ab = array($a,$b); 
  7. //開始排序 
  8. array_multisort($ab[0],SORT_NUMERIC,SORT_DESC,$ab[1],SORT_STRING,SORT_ASC); 
  9. print_r($ab); 
  10. ?> 

說明一下:首先我們用SORT_NUMERIC來聲明對(duì)$ab[0]用數(shù)字類型排序,用SORT_DESC聲明順序是逆序(從大到小),然后我們對(duì)$ab[1]用字符串類型排序,順序是升序(順序)最后數(shù)組$ab的排序結(jié)果是兩者的結(jié)合,先按$ab[0]的逆序,如果$ab[0]中存在大小相同的數(shù)值則按照$ab[1]的順序排列,輸出結(jié)果如下:

  1. Array ( 
  2. [0] => Array ( [0] => 100 [1] => 7 [2] => 7 [3] => 4 [4] => 2 ) 
  3. [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)用的例子,代碼如下:

  1. <?php  
  2. $array[] = array("age"=>20,"name"=>"li"); 
  3. $array[] = array("age"=>21,"name"=>"ai"); 
  4. $array[] = array("age"=>20,"name"=>"ci"); 
  5. $array[] = array("age"=>22,"name"=>"di"); 
  6.  
  7. foreach ($array as $key=>$value){ 
  8.  $age[$key] = $value['age']; 
  9.  $name[$key] = $value['name']; 
  10.  
  11. array_multisort($age,SORT_NUMERIC,SORT_DESC,$name,SORT_STRING,SORT_ASC,$array); 
  12. print_r($array); 
  13. ?> 

這個(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é)果如下—正如我們所想的,代碼如下:

  1. Array ( 
  2. [0] => Array ( [age] => 22 [name] => di ) 
  3. [1] => Array ( [age] => 21 [name] => ai ) 
  4. [2] => Array ( [age] => 20 [name] => ci ) 
  5. [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)目按照字符串比較

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 双牌县| 和田市| 嵩明县| 克什克腾旗| 布拖县| 岳池县| 汉源县| 康保县| 宝兴县| 鹤庆县| 连南| 铁岭市| 石城县| 丹棱县| 阿坝| 天津市| 广平县| 鹿泉市| 林芝县| 田阳县| 阿鲁科尔沁旗| 陈巴尔虎旗| 富阳市| 萨迦县| 满城县| 岱山县| 松滋市| 江油市| 闻喜县| 平顶山市| 沈阳市| 定州市| 葵青区| 波密县| 凤山县| 呼和浩特市| 察雅县| 岫岩| 浏阳市| 澄江县| 梨树县|