PHP常用的數(shù)組函數(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ǔ)到指定長度

三、數(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ù)組長度減1,其他元素向前移動(dòng)一位,數(shù)字鍵名改為從零開始,文字鍵名不變)

array_unshift($arr,"a",array(1,2));在數(shù)組的開頭插入一個(gè)或多個(gè)元素

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

array_walk($arr,'function','words');? 使用用戶函數(shù)對(duì)數(shù)組中的每個(gè)成員進(jìn)行處理(第三個(gè)參數(shù)傳遞給回調(diào)函數(shù)function)

array_walk_recursive($arr, 'function', 'words');?對(duì)數(shù)組中的每個(gè)元素應(yīng)用用戶自定義函數(shù)。在函數(shù)中,數(shù)組的鍵名和鍵值是參數(shù)。該函數(shù)與 array_walk() 函數(shù)的不同在于可以操作更深的數(shù)組(一個(gè)數(shù)組中包含另一個(gè)數(shù)組)。

array_map("function",$arr1,$arr2);? 可以處理多個(gè)數(shù)組(當(dāng)使用兩個(gè)或更多數(shù)組時(shí),他們的長度應(yīng)該相同)

array_filter($arr,"function");? 使用回調(diào)函數(shù)過濾數(shù)組中的每個(gè)元素,如果回調(diào)函數(shù)為TRUE,數(shù)組的當(dāng)前元素會(huì)被包含在返回的結(jié)果數(shù)組中,數(shù)組的鍵名保留不變

array_reduce($arr,"function","*");? 轉(zhuǎn)化為單值函數(shù)(*為數(shù)組的第一個(gè)值)

六、數(shù)組的排序

通過元素值對(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ù)組排序

通過鍵名對(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);? 自然排序(忽略大小寫,忽略鍵名)

七、數(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ì)覆蓋原來的值,而是附加到后面

數(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保留原來的鍵名

//srand((float)microtime()*10000000);?? 隨機(jī)種子觸發(fā)器

array_rand($arr,2);? 從數(shù)組中隨機(jī)取出一個(gè)或 多個(gè)元素

shuffle($arr);? 將數(shù)組的順序打亂

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容