本文實例講述了PHP常見數(shù)組排序方法。
一、數(shù)組操作的基本函數(shù)
數(shù)組的鍵名和值
array_values($arr); 獲得數(shù)組的值
array_keys($arr); 獲得數(shù)組的鍵名
array_flip($arr); 數(shù)組中的值與鍵名互換(如果有重復前面的會被后面的覆蓋)
in_array("apple",$arr); 在數(shù)組中檢索apple
array_search("apple",$arr); 在數(shù)組中檢索apple ,如果存在返回鍵名
array_key_exists("apple",$arr); 檢索給定的鍵名是否存在數(shù)組中
isset($arr[apple]): 檢索給定的鍵名是否存在數(shù)組中
數(shù)組的內(nèi)部指針
current($arr); 返回數(shù)組中的當前單元
pos($arr); 返回數(shù)組中的當前單元
key($arr); 返回數(shù)組中當前單元的鍵名
prev($arr); 將數(shù)組中的內(nèi)部指針倒回一位
next($arr); 將數(shù)組中的內(nèi)部指針向前移動一位
end($arr); 將數(shù)組中的內(nèi)部指針指向最后一個單元
reset($arr; 將數(shù)組中的內(nèi)部指針指向第一個單元
each($arr); 將返回數(shù)組當前元素的一個鍵名/值的構(gòu)造數(shù)組,并使數(shù)組指針向前移動一位
list($key,$value)=each($arr); 獲得數(shù)組當前元素的鍵名和值
數(shù)組和變量之間的轉(zhuǎn)換
extract($arr);用于把數(shù)組中的元素轉(zhuǎn)換成變量導入到當前文件中,鍵名當作變量名,值作為變量值
注:(第二個參數(shù)很重要,可以看手冊使用)使用方法 echo $a;
compact(var1,var2,var3);用給定的變量名創(chuàng)建一個數(shù)組
二、數(shù)組的分段和填充
數(shù)組的分段
array_slice($arr,0,3); 可以將數(shù)組中的一段取出,此函數(shù)忽略鍵名
array_splice($arr,0,3,array("black","maroon")); 可以將數(shù)組中的一段取出,與上個函數(shù)不同在于返回的序列從原數(shù)組中刪除
分割多個數(shù)組
array_chunk($arr,3,TRUE); 可以將一個數(shù)組分割成多個,TRUE為保留原數(shù)組的鍵名
數(shù)組的填充
array_pad($arr,5,'x'); 將一個數(shù)組填補到制定長度
三、數(shù)組與棧
array_push($arr,"apple","pear"); 將一個或多個元素壓入數(shù)組棧的末尾(入棧),返回入棧元素的個數(shù)
array_pop($arr); 將數(shù)組棧的最后一個元素彈出(出棧)
四、數(shù)組與列隊
array_shift($arr);數(shù)組中的第一個元素移出并作為結(jié)果返回(數(shù)組長度減1,其他元素向前移動一位,數(shù)字鍵名改為從零技術(shù),文字鍵名不變)
array_unshift($arr,"a",array(1,2));在數(shù)組的開頭插入一個或多個元素
五、回調(diào)函數(shù)
array_walk($arr,'function','words'); 使用用戶函數(shù)對數(shù)組中的每個成員進行處理(第三個參數(shù)傳遞給回調(diào)函數(shù)function)
array_mpa("function",$arr1,$arr2); 可以處理多個數(shù)組(當使用兩個或更多數(shù)組時,他們的長度應該相同)
array_filter($arr,"function"); 使用回調(diào)函數(shù)過濾數(shù)組中的每個元素,如果回調(diào)函數(shù)為TRUE,數(shù)組的當前元素會被包含在返回的結(jié)果數(shù)組中,數(shù)組的鍵名保留不變
array_reduce($arr,"function","*"); 轉(zhuǎn)化為單值函數(shù)(*為數(shù)組的第一個值)
六、數(shù)組的排序
通過元素值對數(shù)組排序
sort($arr); 由小到大的順序排序(第二個參數(shù)為按什么方式排序)忽略鍵名的數(shù)組排序
rsort($arr); 由大到小的順序排序(第二個參數(shù)為按什么方式排序)忽略鍵名的數(shù)組排序
usort($arr,"function"); 使用用戶自定義的比較函數(shù)對數(shù)組中的值進行排序(function中有兩個參數(shù),0表示相等,正數(shù)表示第一個大于第二個,負數(shù)表示第一個小于第二個)忽略鍵名的數(shù)組排序
asort($arr); 由小到大的順序排序(第二個參數(shù)為按什么方式排序)保留鍵名的數(shù)組排序
arsort($arr); 由大到小的順序排序(第二個參數(shù)為按什么方式排序)保留鍵名的數(shù)組排序
uasort($arr,"function"); 使用用戶自定義的比較函數(shù)對數(shù)組中的值進行排序(function中有兩個參數(shù),0表示相等,正數(shù)表示第一個大于第二個,負數(shù)表示第一個小于第二個)保留鍵名的數(shù)組排序
通過鍵名對數(shù)組排序
ksort($arr); 按照鍵名正序排序
krsort($arr); 按照鍵名逆序排序
uksort($arr,"function"); 使用用戶自定義的比較函數(shù)對數(shù)組中的鍵名進行排序(function中有兩個參數(shù),0表示相等,正數(shù)表示第一個大于第二個,負數(shù)表示第一個小于第二個)
自然排序法排序
natsort($arr); 自然排序(忽略鍵名)
natcasesort($arr); 自然排序(忽略大小寫,忽略鍵名)
七、數(shù)組的計算
數(shù)組元素的求和
array_sum($arr); 對數(shù)組內(nèi)部的所有元素做求和運算
數(shù)組的合并
array_merge($arr1,$arr2); 合并兩個或多個數(shù)組(相同的字符串鍵名,后面的覆蓋前面的,相同的數(shù)字鍵名,后面的不會做覆蓋操作,而是附加到后面)
“+”$arr1+$arr2; 對于相同的鍵名只保留后一個
array_merge_recursive($arr1,$arr2); 遞歸合并操作,如果數(shù)組中有相同的字符串鍵名,這些值將被合并到一個數(shù)組中去。如果一個值本身是一個數(shù)組,將按照相應的鍵名把它合并為另一個數(shù)組。當數(shù)組 具有相同的數(shù)組鍵名時,后一個值將不會覆蓋原來的值,而是附加到后面
數(shù)組的差集
array_diff($arr1,$arr2); 返回差集結(jié)果數(shù)組
array_diff_assoc($arr1,$arr2,$arr3); 返回差集結(jié)果數(shù)組,鍵名也做比較
數(shù)組的交集
array_intersect($arr1,$arr2); 返回交集結(jié)果數(shù)組
array_intersect_assoc($arr1,$arr2); 返回交集結(jié)果數(shù)組,鍵名也做比較
八、其他的數(shù)組函數(shù)
range(0,12); 創(chuàng)建一個包含指定范圍單元的數(shù)組
array_unique($arr); 移除數(shù)組中重復的值,新的數(shù)組中會保留原始的鍵名
array_reverse($arr,TRUE); 返回一個單元順序與原數(shù)組相反的數(shù)組,如果第二個參數(shù)為TRUE保留原來的鍵名
//srand((float)microtime()*10000000); 隨機種子觸發(fā)器
array_rand($arr,2); 從數(shù)組中隨機取出一個或 多個元素
shuffle($arr); 將數(shù)組的順序打亂
分類: 整理分享給大家供大家參考,具體如下:
1.簡單數(shù)組排序 sort()
函數(shù)和rsort()
函數(shù):
bool sort(array array [,int sort_flags]
bool rsort(array array [.int_sort_flags]
參數(shù):第一個參數(shù)是排序數(shù)組對象
第二個參數(shù)是可以選的 可選值:
SORT_REGULAR:是默認值,將自動識別數(shù)組的元素類型進行排序
SORT_NUMERIC:用于數(shù)組元素排序
SORT_STRING:用于字符串排序
SORT_LOCALE_STRING:根據(jù)當前的locale設(shè)置來把元素當作字符串比較
示例:
$a=array(4,7,9,1);
sort($a);
pirnt_r($a);
rsort($a);
print_r($a);
2.根據(jù)鍵名對數(shù)組排序
ksort()
函數(shù)按照鍵名對數(shù)組進行有小到大的排序。 krsort()
與ksort()
函數(shù)相反,排序后為數(shù)組值保持原來的鍵。
示例:
$data= array(5=>"five",8=>"eight",1=>"one",7=>"seven");
ksrot($data);
print_r($data);
krsot($data);
print_r($data);
3.根據(jù)元素值排序
asort()
從小到大 arsort()
從大到小,用這個函數(shù)排序,原始鍵名將被忽略,使用依次數(shù)字重新索引數(shù)組下標
$data=array("a"=>1,"b"=>2,"c"=>3);
asort($data);
print_r($data);
arsort($data);
print_r($data);
4.自然排序
是個非常特殊的排序方式,這種方式使用認知而不是使用計算規(guī)則,這種特性稱為——自然排序法,即數(shù)字從1到9,字母從a-z,短者優(yōu)先。
示例:
$data=array("file1.txt","file11.txt","file111.txt");
natsort($data);//普通自然排序
natcasesort($data);//忽略大小寫
5.根據(jù)用戶自定義排序規(guī)則
bool usort(array array ,callback cmp_function)
bool uasort(array array,callback cmp_function)
bool uksort(array array,callback cmp_function)
自定義回調(diào)函數(shù),需要兩個參數(shù),分別是數(shù)組兩個連續(xù)元素,比較第一個參數(shù)小于,大于,等于第二個參數(shù)是分別返回 0,1,-1
$data= array("ab","abc","a","ac","abcd");
usrot($data,"mysortByLen");
function mysortByLen($one,$two){
if(strlen($one)== strlen($two)){
return 0;
}else{
return (strlen($one)>strlen($two))?1:-1;
}
6.多維數(shù)組排序
array_multisort()
函數(shù)對多個數(shù)組排序,或者根據(jù)某一維或多維對多維數(shù)組排序。
bool array_multisort(array array1 [,mixed arg,[,array ....]])
示例:
$data=array(
array("id"=>1,"name"=>4),
array("id"=>1,"name"=>2),
array("id"=>2,"name"=>3)
);
foreach($data as $key=>$value){
$ids[$key]=$value["id"];
$names[$key]=$value["name"]
}
array_multisort($data,$ids,$names);
print_r($data);
輸出如下:
array(
array("id"=>1,"name"=>2),
array("id"=>1,"name"=>4),
array("id"=>2,"name"=>3)
);
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程序設(shè)計算法總結(jié)》、《php字符串(string)用法總結(jié)》及《PHP常用遍歷算法與技巧總結(jié)》
希望本文所述對大家PHP程序設(shè)計有所幫助。
您可能感興趣的文章:- PHP 數(shù)組排序方法總結(jié) 推薦收藏
- php中二維數(shù)組排序問題方法詳解
- array_multisort實現(xiàn)PHP多維數(shù)組排序示例講解
- php簡單實現(xiàn)多維數(shù)組排序的方法
- PHP 冒泡排序 二分查找 順序查找 二維數(shù)組排序算法函數(shù)的詳解
- php不用內(nèi)置函數(shù)對數(shù)組排序的兩個算法代碼
- php 數(shù)組排序 array_multisort與uasort的區(qū)別
- php關(guān)于array_multisort多維數(shù)組排序的使用說明
- PHP數(shù)組排序之sort、asort與ksort用法實例
- PHP 簡單數(shù)組排序?qū)崿F(xiàn)代碼