程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php數組排序之多維數組與一維數組

php數組排序之多維數組與一維數組

編輯:關於PHP編程

我們知道在php數組中分為多維數組與一維數組,我們下面來分別講述一下php多維數組與一維數組排序原理與實現方法吧。

一維數組

第一組 :sort 和 rsort ,按照PHP數組鍵值的順序asc和逆序desc進行排序,同時破壞原來數組的索引關系——其實是刪除索引之後重新建立從0開始的數字索引。看一下例程:

 代碼如下 復制代碼  <?php
$a = array("a"=>1,2);
sort($a);
var_dump($a);
 
rsort($a);
var_dump($a);
?>
看一下第一個輸出結果,第一個輸出:
array(2) {
  [0]=>
  int(1)
  [1]=>
  int(2)
}
第二個輸出:
array(2) {
  [0]=>
  int(5)
  [1]=>
  int(4)
}

發現沒有我們原來定義的索引a哪裡去了?哪裡去了?可以肯定的說是被他們無情的刪除了,你要是對原來的索引關系並不在意的話,可以使用他們!

第二組函數:asort 和 arsort ,這兩個函數就比較厲害一點了,只要他們可以保留數組原有的索引關系,把上例的sort 和 rsort 分別用這兩個函數替換一下,看運行結果:

 代碼如下 復制代碼 array(2) {
  ["a"]=>
  int(1)
  [0]=>
  int(2)
}
array(2) {
  [0]=>
  int(2)
  ["a"]=>
  int(1)
}

這個一看就明白的,不用說了吧!

第三組PHP數組排序函數:krsort 和 ksort 這兩個不同於以上兩組,這兩函數是對鍵名進行排序的,大家可以把上例的函數替換成這兩個,看看具體運行結果,這裡也不說了,不然這個文章寫的就太長了,怕有些兄弟沒有耐心看到本文的重點,雖然重點就在下邊!

通過自定義函數對PHP數組進行排序,有三個函數分別是:
uasort 通過自定義函數對PHP數組的鍵值進行排序,並且保留原來的索引關系。
uksort 通過自定義函數對PHP數組的鍵名進行排序,並且保留原來的索引關系。
usort通過自定義函數對PHP數組的鍵值進行排序,並且刪除原來的索引關系,從零開始建立新的索引。

這個地方當然需要一個例子:

 代碼如下 復制代碼  <!--p
//首先頂一個函數,這個函數需要接受兩個參數,並且返回值是一定的
//第一個參數等於第二個參數的時候返回0,小於的時候返回-1,大於返回1
 
function cmp($a,$b){
 $a+=1;
 $b+=3;//改變這些值之後進行比較
 
 if($a==$b) return 0;
 return ($a&lt;$b)?-1:1;
}
 
$a =array(1,4,3,5);
uasort($a,'cmp');
var_dump($a);
-->
輸出結果:
array(4) {
  [0]=>
  int(1)
  [3]=>
  int(5)
  [1]=>
  int(4)
  [2]=>
  int(3)
}

多維數組的排序


例如array_multisort($a,$b),$a,$b是兩個數組,如果排序之後,$a數組的第3個元素被排到了第一位,那麼$b的第三個元素不管他在$b中的大小都會排在第一位。看看下邊的程序運行結果:

 代碼如下 復制代碼

<?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);
?>
運行結果:
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” }

很顯然本來是數組b第五個元素的z被排到了第一位!

其實說明白了就是,array_multisort()先把第一個數組按照鍵值的大小排序,然後其它數組都按照第一個數組的調整策略進行調整——第三個元素放到第一位,第二個元素放到第二位……——其實這個多維數組排序算法的最基本體現!

不過需要注意的是:兩個數組的元素個數必須相同,不然就會出現一個警告信息:
Warning: array_multisort() [function.array-multisort]: Array sizes are inconsistent in ……

好了,希望上邊的大家也能用上,咱們還是說主要的吧:array_multisort()對多維數組進行排序,這個功能將來做項目的時候是非常有用的!

首先我們看看對多維數組的每一元素[數組]進行排序的操作方法,很簡單,但是有幾個參數需要說明一下,如果您對sql有所了解一看估計就明白了:

 代碼如下 復制代碼 <?php
//讓我們來構造一個多維數組
$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來聲明對$ab[0]用數字類型排序,用SORT_DESC
聲明順序是逆序(從大到小),然後我們對$ab[1]用字符串類型排序,順序是升序(順序)
最後數組$ab的排序結果是兩者的結合,先按$ab[0]的逆序,如果$ab[0]中存在大小相同的數值則按照$ab[1]的順序排列,輸出結果如下:

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 )
)
是不是很像在數據庫中用order by?其實真的差不多!

現在我們再看一個更加貼近實際應用的例子:

 代碼如下 復制代碼  <?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);
?>

這個例子的$array[]數組,是按照數據庫中讀出的記錄來構造的,我們現在對他們按照年齡從大到小的順序排列,如果年齡相同就按照名字的順序排序。這樣的排序才是我們將來會經常用的到的,
因為array_multisort()需要的排序參數必須是一個列,所以我們用foreach把這個數組的年齡和姓名讀出來,之後呢?
就像上邊的例子一樣,進行排序,最後一個參數$array想必大家也看見了,是的這裡需要聲明對哪個數組進行排序,因為我們前邊兩個參數在形式上已經和需要排序的PHP數組沒有關系了,雖然其實他們就是$array中的數據——我們從$array中抽取的列——排序當然是需要列,還沒見過用行數據進行排序的呢!

輸出結果如下——正如我們所想的:

 代碼如下 復制代碼 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 )
)

看到了吧,其實也很簡單,就是那幾個需要大寫的參數有點煩人而已!雖說也有點難以理解,但是理解了就好了,將來很有用的哦!
附錄:
排序順序標志:

SORT_ASC – 按照上升順序排序
SORT_DESC – 按照下降順序排序

排序類型標志:

SORT_REGULAR – 將項目按照通常方法比較
SORT_NUMERIC – 將項目按照數值比較
SORT_STRING – 將項目按照字符串比較

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved