PHP數(shù)組常用函數(shù)分類(lèi)整理
一捏肢、數(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');??使用用戶(hù)函數(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ù)為T(mén)RUE慌闭,數(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");??使用用戶(hù)自定義的比較函數(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");??使用用戶(hù)自定義的比較函數(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");??使用用戶(hù)自定義的比較函數(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ù)為T(mén)RUE保留原來(lái)的鍵名
//srand((float)microtime()*10000000);???隨機(jī)種子觸發(fā)器
array_rand($arr,2);??從數(shù)組中隨機(jī)取出一個(gè)或?多個(gè)元素
shuffle($arr);??將數(shù)組的順序打亂