您好,登錄后才能下訂單哦!
小編給大家分享一下PHP數(shù)組操作的基本函數(shù)有哪些,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!
數(shù)組的鍵名和值 array_values($arr); 獲得數(shù)組的值 array_keys($arr); 獲得數(shù)組的鍵名 array_flip($arr); 數(shù)組中的值與鍵名互換(如果有重復(fù)前面的會被后面的覆蓋) 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)部指針向前移動一位 end($arr); 將數(shù)組中的內(nèi)部指針指向最后一個單元 reset($arr; 將數(shù)組中的內(nèi)部指針指向第一個單元 each($arr); 將返回?cái)?shù)組當(dāng)前元素的一個鍵名/值的構(gòu)造數(shù)組,并使數(shù)組指針向前移動一位 list($key,$value)=each($arr); 獲得數(shù)組當(dāng)前元素的鍵名和值 數(shù)組和變量之間的轉(zhuǎn)換 extract($arr);用于把數(shù)組中的元素轉(zhuǎn)換成變量導(dǎo)入到當(dāng)前文件中,鍵名當(dāng)作變量名,值作為變量值 注:(第二個參數(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ù)組填補(bǔ)到制定長度
三、數(shù)組與棧
array_push($arr,"apple","pear"); 將一個或多個元素壓入數(shù)組棧的末尾(入棧),返回入棧元素的個數(shù) array_pop($arr); 將數(shù)組棧的最后一個元素彈出(出棧)
四、數(shù)組與列隊(duì)
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ù)組中的每個成員進(jìn)行處理(第三個參數(shù)傳遞給回調(diào)函數(shù)function) array_mpa("function",$arr1,$arr2); 可以處理多個數(shù)組(當(dāng)使用兩個或更多數(shù)組時,他們的長度應(yīng)該相同) array_filter($arr,"function"); 使用回調(diào)函數(shù)過濾數(shù)組中的每個元素,如果回調(diào)函數(shù)為TRUE,數(shù)組的當(dāng)前元素會被包含在返回的結(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ù)組中的值進(jìn)行排序(function中有兩個參數(shù),0表示相等,正數(shù)表示第一個大于第二個,負(fù)數(shù)表示第一個小于第二個)忽略鍵名的數(shù)組排序 asort($arr); 由小到大的順序排序(第二個參數(shù)為按什么方式排序)保留鍵名的數(shù)組排序 arsort($arr); 由大到小的順序排序(第二個參數(shù)為按什么方式排序)保留鍵名的數(shù)組排序 uasort($arr,"function"); 使用用戶自定義的比較函數(shù)對數(shù)組中的值進(jìn)行排序(function中有兩個參數(shù),0表示相等,正數(shù)表示第一個大于第二個,負(fù)數(shù)表示第一個小于第二個)保留鍵名的數(shù)組排序 通過鍵名對數(shù)組排序 ksort($arr); 按照鍵名正序排序 krsort($arr); 按照鍵名逆序排序 uksort($arr,"function"); 使用用戶自定義的比較函數(shù)對數(shù)組中的鍵名進(jìn)行排序(function中有兩個參數(shù),0表示相等,正數(shù)表示第一個大于第二個,負(fù)數(shù)表示第一個小于第二個) 自然排序法排序 natsort($arr); 自然排序(忽略鍵名) natcasesort($arr); 自然排序(忽略大小寫,忽略鍵名)
七、數(shù)組的計(jì)算
數(shù)組元素的求和 array_sum($arr); 對數(shù)組內(nèi)部的所有元素做求和運(yùn)算 數(shù)組的合并 array_merge($arr1,$arr2); 合并兩個或多個數(shù)組(相同的字符串鍵名,后面的覆蓋前面的,相同的數(shù)字鍵名,后面的不會做覆蓋操作,而是附加到后面) “+”$arr1+$arr2; 對于相同的鍵名只保留后一個 array_merge_recursive($arr1,$arr2); 遞歸合并操作,如果數(shù)組中有相同的字符串鍵名,這些值將被合并到一個數(shù)組中去。如果一個值本身是一個數(shù)組,將按照相應(yīng)的鍵名把它合并為另一個數(shù)組。當(dāng)數(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ù)組中重復(fù)的值,新的數(shù)組中會保留原始的鍵名 array_reverse($arr,TRUE); 返回一個單元順序與原數(shù)組相反的數(shù)組,如果第二個參數(shù)為TRUE保留原來的鍵名 //srand((float)microtime()*10000000); 隨機(jī)種子觸發(fā)器 array_rand($arr,2); 從數(shù)組中隨機(jī)取出一個或 多個元素 shuffle($arr); 將數(shù)組的順序打亂
看完了這篇文章,相信你對PHP數(shù)組操作的基本函數(shù)有哪些有了一定的了解,想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。