PHP數(shù)組的常用函數(shù)有哪些?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
為井陘礦等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及井陘礦網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都網(wǎng)站制作、網(wǎng)站建設(shè)、井陘礦網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!
一、數(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)一位(php7已廢除)
list($key,$value)=each($arr); 獲得數(shù)組當(dāng)前元素的鍵名和值
數(shù)組和變量之間的轉(zhuǎn)換
extract($arr);用于把數(shù)組中的元素轉(zhuǎn)換成變量導(dǎo)入到當(dāng)前文件中,鍵名當(dāng)作變量名,值作為變量值
注:(第二個(gè)參數(shù)很重要,可以看手冊使用)使用方法 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ù)字鍵名改為從零技術(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_mpa(“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ù)組的順序打亂
本類函數(shù)允許用多種方法來操作數(shù)組和與之交互。數(shù)組的本質(zhì)是儲(chǔ)存,管理和操作一組變量。
PHP 支持一維和多維數(shù)組,可以是用戶創(chuàng)建或由另一個(gè)函數(shù)創(chuàng)建。有一些特定的數(shù)據(jù)庫處理函數(shù)可以從數(shù)據(jù)庫查詢中生成數(shù)組,還有一些函數(shù)返回?cái)?shù)組。
array_change_key_case — 返回字符串鍵名全為小寫或大寫的數(shù)組
array_chunk — 將一個(gè)數(shù)組分割成多個(gè)
array_combine — 創(chuàng)建一個(gè)數(shù)組,用一個(gè)數(shù)組的值作為其鍵名,另一個(gè)數(shù)組的值作為其值
array_count_values — 統(tǒng)計(jì)數(shù)組中所有的值出現(xiàn)的次數(shù)
array_diff_assoc — 帶索引檢查計(jì)算數(shù)組的差集
array_diff_key — 使用鍵名比較計(jì)算數(shù)組的差集
array_diff_uassoc — 用用戶提供的回調(diào)函數(shù)做索引檢查來計(jì)算數(shù)組的差集
array_diff_ukey — 用回調(diào)函數(shù)對(duì)鍵名比較計(jì)算數(shù)組的差集
array_diff — 計(jì)算數(shù)組的差集
array_fill_keys — Fill an array with values, specifying keys
array_fill — 用給定的值填充數(shù)組
array_filter — 用回調(diào)函數(shù)過濾數(shù)組中的單元
array_flip — 交換數(shù)組中的鍵和值
array_intersect_assoc — 帶索引檢查計(jì)算數(shù)組的交集
array_intersect_key — 使用鍵名比較計(jì)算數(shù)組的交集
array_intersect_uassoc — 帶索引檢查計(jì)算數(shù)組的交集,用回調(diào)函數(shù)比較索引
array_intersect_ukey — 用回調(diào)函數(shù)比較鍵名來計(jì)算數(shù)組的交集
array_intersect — 計(jì)算數(shù)組的交集
array_key_exists — 檢查給定的鍵名或索引是否存在于數(shù)組中
array_keys — 返回?cái)?shù)組中所有的鍵名
array_map — 將回調(diào)函數(shù)作用到給定數(shù)組的單元上
array_merge_recursive — 遞歸地合并一個(gè)或多個(gè)數(shù)組
array_merge — 合并一個(gè)或多個(gè)數(shù)組
array_multisort — 對(duì)多個(gè)數(shù)組或多維數(shù)組進(jìn)行排序
array_pad — 用值將數(shù)組填補(bǔ)到指定長度
array_pop — 將數(shù)組最后一個(gè)單元彈出(出棧)
array_product — 計(jì)算數(shù)組中所有值的乘積
array_push — 將一個(gè)或多個(gè)單元壓入數(shù)組的末尾(入棧)
array_rand — 從數(shù)組中隨機(jī)取出一個(gè)或多個(gè)單元
array_reduce — 用回調(diào)函數(shù)迭代地將數(shù)組簡化為單一的值
array_reverse — 返回一個(gè)單元順序相反的數(shù)組
array_search — 在數(shù)組中搜索給定的值,如果成功則返回相應(yīng)的鍵名
array_shift — 將數(shù)組開頭的單元移出數(shù)組
array_slice — 從數(shù)組中取出一段
array_splice — 把數(shù)組中的一部分去掉并用其它值取代
array_sum — 計(jì)算數(shù)組中所有值的和
array_udiff_assoc — 帶索引檢查計(jì)算數(shù)組的差集,用回調(diào)函數(shù)比較數(shù)據(jù)
array_udiff_uassoc — 帶索引檢查計(jì)算數(shù)組的差集,用回調(diào)函數(shù)比較數(shù)據(jù)和索引
array_udiff — 用回調(diào)函數(shù)比較數(shù)據(jù)來計(jì)算數(shù)組的差集
array_uintersect_assoc — 帶索引檢查計(jì)算數(shù)組的交集,用回調(diào)函數(shù)比較數(shù)據(jù)
array_uintersect_uassoc — 帶索引檢查計(jì)算數(shù)組的交集,用回調(diào)函數(shù)比較數(shù)據(jù)和索引
array_uintersect — 計(jì)算數(shù)組的交集,用回調(diào)函數(shù)比較數(shù)據(jù)
array_unique — 移除數(shù)組中重復(fù)的值
array_unshift — 在數(shù)組開頭插入一個(gè)或多個(gè)單元
array_values — 返回?cái)?shù)組中所有的值
array_walk_recursive — 對(duì)數(shù)組中的每個(gè)成員遞歸地應(yīng)用用戶函數(shù)
array_walk — 對(duì)數(shù)組中的每個(gè)成員應(yīng)用用戶函數(shù)
array — 新建一個(gè)數(shù)組
arsort — 對(duì)數(shù)組進(jìn)行逆向排序并保持索引關(guān)系
asort — 對(duì)數(shù)組進(jìn)行排序并保持索引關(guān)系
compact — 建立一個(gè)數(shù)組,包括變量名和它們的值
count — 計(jì)算數(shù)組中的單元數(shù)目或?qū)ο笾械膶傩詡€(gè)數(shù)
current — 返回?cái)?shù)組中的當(dāng)前單元
each — 返回?cái)?shù)組中當(dāng)前的鍵/值對(duì)并將數(shù)組指針向前移動(dòng)一步
end — 將數(shù)組的內(nèi)部指針指向最后一個(gè)單元
extract — 從數(shù)組中將變量導(dǎo)入到當(dāng)前的符號(hào)表
in_array — 檢查數(shù)組中是否存在某個(gè)值
key — 從關(guān)聯(lián)數(shù)組中取得鍵名
krsort — 對(duì)數(shù)組按照鍵名逆向排序
ksort — 對(duì)數(shù)組按照鍵名排序
list — 把數(shù)組中的值賦給一些變量
natcasesort — 用“自然排序”算法對(duì)數(shù)組進(jìn)行不區(qū)分大小寫字母的排序
natsort — 用“自然排序”算法對(duì)數(shù)組排序
next — 將數(shù)組中的內(nèi)部指針向前移動(dòng)一位
pos — current() 的別名
prev — 將數(shù)組的內(nèi)部指針倒回一位
range — 建立一個(gè)包含指定范圍單元的數(shù)組
reset — 將數(shù)組的內(nèi)部指針指向第一個(gè)單元
rsort — 對(duì)數(shù)組逆向排序
shuffle — 將數(shù)組打亂
sizeof — count() 的別名
sort — 對(duì)數(shù)組排序
uasort — 使用用戶自定義的比較函數(shù)對(duì)數(shù)組中的值進(jìn)行排序并保持索引關(guān)聯(lián)
uksort — 使用用戶自定義的比較函數(shù)對(duì)數(shù)組中的鍵名進(jìn)行排序
usort — 使用用戶自定義的比較函數(shù)對(duì)數(shù)組中的值進(jìn)行排序
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)的支持。