主頁(yè) > 知識(shí)庫(kù) > PHP常見(jiàn)數(shù)組排序方法小結(jié)

PHP常見(jiàn)數(shù)組排序方法小結(jié)

熱門標(biāo)簽:電子圍欄 阿里云 銀行業(yè)務(wù) Linux服務(wù)器 科大訊飛語(yǔ)音識(shí)別系統(tǒng) 服務(wù)器配置 團(tuán)購(gòu)網(wǎng)站 Mysql連接數(shù)設(shè)置

本文實(shí)例講述了PHP常見(jiàn)數(shù)組排序方法。

一、數(shù)組操作的基本函數(shù)

數(shù)組的鍵名和值
array_values($arr); 獲得數(shù)組的值
array_keys($arr); 獲得數(shù)組的鍵名
array_flip($arr); 數(shù)組中的值與鍵名互換(如果有重復(fù)前面的會(huì)被后面的覆蓋)
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); 返回?cái)?shù)組中的當(dāng)前單元
pos($arr); 返回?cái)?shù)組中的當(dāng)前單元
key($arr); 返回?cái)?shù)組中當(dāng)前單元的鍵名
prev($arr); 將數(shù)組中的內(nèi)部指針倒回一位
next($arr); 將數(shù)組中的內(nèi)部指針向前移動(dòng)一位
end($arr); 將數(shù)組中的內(nèi)部指針指向最后一個(gè)單元
reset($arr; 將數(shù)組中的內(nèi)部指針指向第一個(gè)單元
each($arr); 將返回?cái)?shù)組當(dāng)前元素的一個(gè)鍵名/值的構(gòu)造數(shù)組,并使數(shù)組指針向前移動(dòng)一位
list($key,$value)=each($arr); 獲得數(shù)組當(dāng)前元素的鍵名和值

數(shù)組和變量之間的轉(zhuǎn)換
extract($arr);用于把數(shù)組中的元素轉(zhuǎn)換成變量導(dǎo)入到當(dāng)前文件中,鍵名當(dāng)作變量名,值作為變量值
注:(第二個(gè)參數(shù)很重要,可以看手冊(cè)使用)使用方法 echo $a;
compact(var1,var2,var3);用給定的變量名創(chuàng)建一個(gè)數(shù)組

二、數(shù)組的分段和填充

數(shù)組的分段
array_slice($arr,0,3); 可以將數(shù)組中的一段取出,此函數(shù)忽略鍵名
array_splice($arr,0,3,array("black","maroon")); 可以將數(shù)組中的一段取出,與上個(gè)函數(shù)不同在于返回的序列從原數(shù)組中刪除

分割多個(gè)數(shù)組
array_chunk($arr,3,TRUE); 可以將一個(gè)數(shù)組分割成多個(gè),TRUE為保留原數(shù)組的鍵名

數(shù)組的填充
array_pad($arr,5,'x'); 將一個(gè)數(shù)組填補(bǔ)到制定長(zhǎng)度

三、數(shù)組與棧

array_push($arr,"apple","pear"); 將一個(gè)或多個(gè)元素壓入數(shù)組棧的末尾(入棧),返回入棧元素的個(gè)數(shù)
array_pop($arr); 將數(shù)組棧的最后一個(gè)元素彈出(出棧)

四、數(shù)組與列隊(duì)

array_shift($arr);數(shù)組中的第一個(gè)元素移出并作為結(jié)果返回(數(shù)組長(zhǎng)度減1,其他元素向前移動(dòng)一位,數(shù)字鍵名改為從零技術(shù),文字鍵名不變)
array_unshift($arr,"a",array(1,2));在數(shù)組的開(kāi)頭插入一個(gè)或多個(gè)元素

五、回調(diào)函數(shù)

array_walk($arr,'function','words'); 使用用戶函數(shù)對(duì)數(shù)組中的每個(gè)成員進(jìn)行處理(第三個(gè)參數(shù)傳遞給回調(diào)函數(shù)function)
array_mpa("function",$arr1,$arr2); 可以處理多個(gè)數(shù)組(當(dāng)使用兩個(gè)或更多數(shù)組時(shí),他們的長(zhǎng)度應(yīng)該相同)
array_filter($arr,"function"); 使用回調(diào)函數(shù)過(guò)濾數(shù)組中的每個(gè)元素,如果回調(diào)函數(shù)為TRUE,數(shù)組的當(dāng)前元素會(huì)被包含在返回的結(jié)果數(shù)組中,數(shù)組的鍵名保留不變
array_reduce($arr,"function","*"); 轉(zhuǎn)化為單值函數(shù)(*為數(shù)組的第一個(gè)值)

六、數(shù)組的排序

通過(guò)元素值對(duì)數(shù)組排序
sort($arr); 由小到大的順序排序(第二個(gè)參數(shù)為按什么方式排序)忽略鍵名的數(shù)組排序
rsort($arr); 由大到小的順序排序(第二個(gè)參數(shù)為按什么方式排序)忽略鍵名的數(shù)組排序
usort($arr,"function"); 使用用戶自定義的比較函數(shù)對(duì)數(shù)組中的值進(jìn)行排序(function中有兩個(gè)參數(shù),0表示相等,正數(shù)表示第一個(gè)大于第二個(gè),負(fù)數(shù)表示第一個(gè)小于第二個(gè))忽略鍵名的數(shù)組排序
asort($arr); 由小到大的順序排序(第二個(gè)參數(shù)為按什么方式排序)保留鍵名的數(shù)組排序
arsort($arr); 由大到小的順序排序(第二個(gè)參數(shù)為按什么方式排序)保留鍵名的數(shù)組排序
uasort($arr,"function"); 使用用戶自定義的比較函數(shù)對(duì)數(shù)組中的值進(jìn)行排序(function中有兩個(gè)參數(shù),0表示相等,正數(shù)表示第一個(gè)大于第二個(gè),負(fù)數(shù)表示第一個(gè)小于第二個(gè))保留鍵名的數(shù)組排序

通過(guò)鍵名對(duì)數(shù)組排序
ksort($arr); 按照鍵名正序排序
krsort($arr); 按照鍵名逆序排序
uksort($arr,"function"); 使用用戶自定義的比較函數(shù)對(duì)數(shù)組中的鍵名進(jìn)行排序(function中有兩個(gè)參數(shù),0表示相等,正數(shù)表示第一個(gè)大于第二個(gè),負(fù)數(shù)表示第一個(gè)小于第二個(gè))

自然排序法排序

natsort($arr); 自然排序(忽略鍵名)
natcasesort($arr); 自然排序(忽略大小寫(xiě),忽略鍵名)

七、數(shù)組的計(jì)算

數(shù)組元素的求和
array_sum($arr); 對(duì)數(shù)組內(nèi)部的所有元素做求和運(yùn)算

數(shù)組的合并
array_merge($arr1,$arr2); 合并兩個(gè)或多個(gè)數(shù)組(相同的字符串鍵名,后面的覆蓋前面的,相同的數(shù)字鍵名,后面的不會(huì)做覆蓋操作,而是附加到后面)
“+”$arr1+$arr2; 對(duì)于相同的鍵名只保留后一個(gè)
array_merge_recursive($arr1,$arr2); 遞歸合并操作,如果數(shù)組中有相同的字符串鍵名,這些值將被合并到一個(gè)數(shù)組中去。如果一個(gè)值本身是一個(gè)數(shù)組,將按照相應(yīng)的鍵名把它合并為另一個(gè)數(shù)組。當(dāng)數(shù)組 具有相同的數(shù)組鍵名時(shí),后一個(gè)值將不會(huì)覆蓋原來(lái)的值,而是附加到后面

數(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)建一個(gè)包含指定范圍單元的數(shù)組
array_unique($arr); 移除數(shù)組中重復(fù)的值,新的數(shù)組中會(huì)保留原始的鍵名
array_reverse($arr,TRUE); 返回一個(gè)單元順序與原數(shù)組相反的數(shù)組,如果第二個(gè)參數(shù)為TRUE保留原來(lái)的鍵名
//srand((float)microtime()*10000000); 隨機(jī)種子觸發(fā)器
array_rand($arr,2); 從數(shù)組中隨機(jī)取出一個(gè)或 多個(gè)元素
shuffle($arr); 將數(shù)組的順序打亂

分類: 整理分享給大家供大家參考,具體如下:

1.簡(jiǎn)單數(shù)組排序 sort() 函數(shù)和rsort() 函數(shù):

bool sort(array array [,int sort_flags]

bool rsort(array array [.int_sort_flags]

參數(shù):第一個(gè)參數(shù)是排序數(shù)組對(duì)象

第二個(gè)參數(shù)是可以選的 可選值:

SORT_REGULAR:是默認(rèn)值,將自動(dòng)識(shí)別數(shù)組的元素類型進(jìn)行排序
SORT_NUMERIC:用于數(shù)組元素排序
SORT_STRING:用于字符串排序
SORT_LOCALE_STRING:根據(jù)當(dāng)前的locale設(shè)置來(lái)把元素當(dāng)作字符串比較

示例:

$a=array(4,7,9,1);
sort($a);
pirnt_r($a);
rsort($a);
print_r($a);

2.根據(jù)鍵名對(duì)數(shù)組排序

ksort() 函數(shù)按照鍵名對(duì)數(shù)組進(jìn)行有小到大的排序。 krsort()ksort()函數(shù)相反,排序后為數(shù)組值保持原來(lái)的鍵。

示例:

$data= array(5=>"five",8=>"eight",1=>"one",7=>"seven");
ksrot($data);
print_r($data);
krsot($data);
print_r($data);

3.根據(jù)元素值排序

asort() 從小到大 arsort() 從大到小,用這個(gè)函數(shù)排序,原始鍵名將被忽略,使用依次數(shù)字重新索引數(shù)組下標(biāo)

$data=array("a"=>1,"b"=>2,"c"=>3);
asort($data);
print_r($data);
arsort($data);
print_r($data);

4.自然排序

是個(gè)非常特殊的排序方式,這種方式使用認(rèn)知而不是使用計(jì)算規(guī)則,這種特性稱為——自然排序法,即數(shù)字從1到9,字母從a-z,短者優(yōu)先。

示例:

$data=array("file1.txt","file11.txt","file111.txt");
natsort($data);//普通自然排序
natcasesort($data);//忽略大小寫(xiě)

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ù),需要兩個(gè)參數(shù),分別是數(shù)組兩個(gè)連續(xù)元素,比較第一個(gè)參數(shù)小于,大于,等于第二個(gè)參數(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ù)對(duì)多個(gè)數(shù)組排序,或者根據(jù)某一維或多維對(duì)多維數(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)于排序的演示工具供大家參考:

在線動(dòng)畫(huà)演示插入/選擇/冒泡/歸并/希爾/快速排序算法過(guò)程工具:
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è)計(jì)算法總結(jié)》、《php字符串(string)用法總結(jié)》及《PHP常用遍歷算法與技巧總結(jié)》

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • PHP 數(shù)組排序方法總結(jié) 推薦收藏
  • php中二維數(shù)組排序問(wèn)題方法詳解
  • array_multisort實(shí)現(xiàn)PHP多維數(shù)組排序示例講解
  • php簡(jiǎn)單實(shí)現(xiàn)多維數(shù)組排序的方法
  • PHP 冒泡排序 二分查找 順序查找 二維數(shù)組排序算法函數(shù)的詳解
  • php不用內(nèi)置函數(shù)對(duì)數(shù)組排序的兩個(gè)算法代碼
  • php 數(shù)組排序 array_multisort與uasort的區(qū)別
  • php關(guān)于array_multisort多維數(shù)組排序的使用說(shuō)明
  • PHP數(shù)組排序之sort、asort與ksort用法實(shí)例
  • PHP 簡(jiǎn)單數(shù)組排序?qū)崿F(xiàn)代碼

標(biāo)簽:大理 棗莊 廣元 蚌埠 衡水 萍鄉(xiāng) 衢州 江蘇

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP常見(jiàn)數(shù)組排序方法小結(jié)》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266