您好,登錄后才能下訂單哦!
小編給大家分享一下PHP常見數(shù)組函數(shù)與實(shí)例有哪些,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
一、數(shù)組的一些關(guān)于鍵名和值的基礎(chǔ)操作函數(shù)
1.獲取數(shù)組所有的鍵或值:array_keys()
array_values()
$arr_keys = array_keys($array);$arr_values = array_values($arr);
2.交換數(shù)組中鍵和值的位置,若重復(fù)前面的會被后面的覆蓋:array_flip()
$arr2 = array_flip($arr);
3.給定的值是否在數(shù)組中:in_array(value,array)
$bool = in_array('hello',$arr);
4.在數(shù)組中搜索某個值,在則返回它的鍵,不在則返回FALSE:array_search()
$bool = array_search('hello',$arr);
5.給定鍵是否存在數(shù)組中:isset(array[key])
和array_key_exists(key,array)
$bool = array_key_exists('a',$arr);
6.獲取數(shù)組元素的個數(shù):count(array,mode)
,mode為1時表示遞歸地對數(shù)組進(jìn)行計(jì)數(shù),默認(rèn)為0。別名sizeof()
$n = count($arr); //等價于:$n = sizeof($arr);
7.將數(shù)組中的鍵名改為全小寫或大寫:array_change_key_case(array,case)
。case有兩個常用量:CASE_UPPER
或CASE_LOWER
(默認(rèn)值),即默認(rèn)全小寫
$lowarr = array_change_key_case($arr,CASE_LOWER);
8.統(tǒng)計(jì)數(shù)組中所有的值出現(xiàn)的次數(shù):array_count_value(array)
。返回一個數(shù)組,鍵是原數(shù)組的值,值是這個元素在原數(shù)組出現(xiàn)的次數(shù)
$arr_count = array_count_values($arr);
9.得到數(shù)組的第一個或最后一個鍵名:array_key_first(array)
、array_key_last(array)
$key = array_key_first($arr)
10.彈出數(shù)組的最后一個元素:
$last = array_pop($array);
將一個或多個單元壓入數(shù)組的末尾或數(shù)組的開頭,并返回新數(shù)組的個數(shù):
$new_array = array_push($array,$value1,$value2,...);$new_array = array_unshift($array,$value1,$value2,...);
11.將數(shù)組反序:array_reverse(array)
$reverse = array_reverse($arr)
12.對數(shù)組中所有值求和或求乘積:
$sum = array_sum($array);$product = array_product($array);
13.去除數(shù)組中重復(fù)的值:
array_unique($array,,SORT_STRING);sort_falgs參數(shù)用于修改排序行為:SORT_NUMERIC - 按照數(shù)字形式比較、SORT_STRING - 按照字符串形式比較
14.打亂數(shù)組:shuffle(array)
$bool = shuffle($arr);
15.從數(shù)組中隨機(jī)取得一個或多個鍵名:array_rand(array,num=1)
,返回包含隨機(jī)鍵名的數(shù)組。
二、數(shù)組的一些關(guān)于創(chuàng)建和分割的操作函數(shù)總結(jié)
1.將一個數(shù)組分割成多個數(shù)組:array_chunk(array,size,preserve_keys)
參數(shù):size
:指明每個數(shù)組的元素個數(shù)preserve_keys
:指明是否保留原來的鍵名,默認(rèn)為false
。
函數(shù)返回一個二維數(shù)組
$myarr = array_chunk($arr,2)
2.創(chuàng)建一個數(shù)組,用一個數(shù)組的值作為其鍵名,另一個數(shù)組的值作為其值:array_combine(keys,values)
$arr_1 = ['A','B','C'];$arr_2 = ['a','b','c'];$arr_3 = array_combine($arr_1,$arr_2);
3.使用指定的鍵和值填充數(shù)組:array_fill_keys(keys,value)
$keys = array('foo', 5, 10, 'bar');$a = array_fill_keys($keys, 'banana');
4.用給定的值填充數(shù)組:array_fill(start_index,num,value)
參數(shù):start_index
:數(shù)組的第一個索引num
:插入元素的數(shù)量,即數(shù)組的長度,必須為非負(fù)數(shù)value
:用來填充的值
$arr = array_fill(0,10,'myname');
5.合并一個或多個數(shù)組:array_merge(array1,array2...)
鍵名相同時,若是字符鍵名則會被覆蓋,數(shù)字鍵名則不會被覆蓋,而是附加到后面
$a = array_merge($arr_1,$arr_2);
6.遞歸的合并一個或多個數(shù)組:array_merge_recursive(array_1,array_2,...)
如果數(shù)組具有相同的數(shù)組鍵名,后一個值將不會覆蓋原來的值,而是附加到后面.
7.以指定長度將一個值填充進(jìn)數(shù)組:array_pad(array,size,value)
參數(shù):size
:填充后數(shù)組的長度,為正則填充到數(shù)組的右側(cè),為負(fù)則填充到數(shù)組的左側(cè)value
:用來填充的值
8.從數(shù)組中取出一段:array_slice(array,offset,length,preserve_keys)
參數(shù):offset
:開始的偏移量,正負(fù)皆可length
:取得的長度,正數(shù)表示取得元素的個數(shù),負(fù)數(shù)表示距離數(shù)組末尾的距離preserve_keys
:是否保留原來的鍵名
10.去掉數(shù)組中的某一部分并用其它值取代:array_splice(array,offset,length,replacement_array)
參數(shù):replacement_array
:移除的單元被此數(shù)組中的單元替代
11.使用變量創(chuàng)建數(shù)組:compact(var1,var2,...)
,變量名為鍵名,變量值為元素的值
12.從數(shù)組中導(dǎo)出變量:extract(array)
,鍵名為變量名,值為變量的值
13.把數(shù)組的值賦予變量:list(var1,var2,...)
list($drink, , $power) = array('coffee', 'brown', 'caffeine');
14.根據(jù)范圍創(chuàng)建數(shù)組,包含指定的元素:range(start,end,step)
range(0,8,2) ==> [0,2,4,6,8]
三、數(shù)組排序基本函數(shù)名為 sort
可以添加其他拓展:r表示逆向排序,k表示對鍵名進(jìn)行排序,a表示保持索引關(guān)系,u表示用自定義的函數(shù)進(jìn)行比較 1.詳細(xì)介紹sort函數(shù)的情況,其他的函數(shù)類似
/*bool sort ( array &$array [, int $sort_flags = SORT_REGULAR ] )SORT_REGULAR參數(shù)可以用以下值改變排序的行為:SORT_REGULAR - 正常比較單元(不改變類型)SORT_NUMERIC - 單元被作為數(shù)字來比較SORT_STRING - 單元被作為字符串來比較SORT_LOCALE_STRING - 根據(jù)當(dāng)前的區(qū)域(locale)設(shè)置來把單元當(dāng)作字符串比較,可以用 setlocale() 來改變。SORT_NATURAL - 和 natsort() 類似對每個單元以“自然的順序”對字符串進(jìn)行排序。 PHP 5.4.0 中新增的。SORT_FLAG_CASE - 能夠與 SORT_STRING 或 SORT_NATURAL 合并(OR 位運(yùn)算),不區(qū)分大小寫排序字符串。 */
排序函數(shù)分類大致如下:
2.sort()、rsort():對值進(jìn)行升序和降序的排序3.ksort()、krsort():對鍵名進(jìn)行升序和降序的排序4.asort()、arsort():保持索引關(guān)系的同時,對值進(jìn)行升序和降序的排序5.usort()、uksort()、uasort():使用自定義的排序函數(shù),進(jìn)行按值的升序排序、按鍵名的升序排序、保持索引關(guān)系的升序排序6.natsort():使用自然排序算法對數(shù)組進(jìn)行排序7.natcasesort():使用自然排序算法對數(shù)組進(jìn)行不區(qū)分大小寫字母的排序
四、數(shù)組運(yùn)算
數(shù)組差集的計(jì)算 u表示用自定義的回調(diào)函數(shù),diff表示用數(shù)據(jù)做差集,assoc表示用索引做差集
1.計(jì)算數(shù)組的差集:array_diff(array1,array2,...)
對比array1和其他數(shù)組,返回在array1中但不在其他數(shù)組中的值。返回一個數(shù)組,但是鍵名不保留
2.用回調(diào)函數(shù)比較數(shù)據(jù)來計(jì)算數(shù)組的差集:array_udiff(arr1,arr2,...,value_cpmpare_func)
使用用戶自定義的函數(shù)進(jìn)行數(shù)據(jù)比較,而不是內(nèi)置的函數(shù)。
3.使用鍵名比較計(jì)算數(shù)組的差集:array_diff_key(array1,array2,...)
使用鍵名而不是值來進(jìn)行差集計(jì)算
4.用回調(diào)函數(shù)對鍵名比較計(jì)算數(shù)組的差集:array_diff_ukey(arr1,arr2,...,key_compare_func)
5.帶索引檢查計(jì)算數(shù)組的差集:array_diff_assoc(array1,array2,..)
同時使用鍵名和值來進(jìn)行差集計(jì)算
6.帶索引檢查計(jì)算數(shù)組的差集,用回調(diào)函數(shù)比較索引:array_diff_uassoc(arr1,arr2,...,key_compare_func)
key_compare_func
:用戶自定義的用于比較鍵名的函數(shù)。
7.帶索引檢查計(jì)算數(shù)組的差集,用回調(diào)函數(shù)比較數(shù)據(jù):array_udiff_assoc(arr1,arr2,...,value_cpmpare_func)
value_cpmpare_func
:用戶自定義的用于比較數(shù)據(jù)的函數(shù)
8.用回調(diào)函數(shù)比較數(shù)據(jù)和索引,計(jì)算數(shù)組的差集:array_udiff_uassoc(arr1,arr2,...,value_cpmpare_func,key_compare_func)
數(shù)組交集的計(jì)算 同差集一樣,也有8個函數(shù):
array_intersect() 使用數(shù)據(jù)進(jìn)行交集比較 array_uintersect() 使用數(shù)據(jù)進(jìn)行交集比較,但是自定義函數(shù)比較 array_intersect_key() 使用鍵名進(jìn)行交集比較 array_intersect_ukey() 使用鍵名進(jìn)行交比較,但是自定義函數(shù)比較 array_intersect_assoc() 同時使用數(shù)據(jù)和鍵名 array_intersect_uassoc() 同時使用數(shù)據(jù)和鍵名,但是鍵名使用自定義函數(shù)比較 array_uintersect_assoc() 同時使用數(shù)據(jù)和鍵名,但是數(shù)據(jù)使用自定義函數(shù)比較 array_uintersect_uassoc() 同時使用數(shù)據(jù)和鍵名,都使用自定義函數(shù)
看完了這篇文章,相信你對“PHP常見數(shù)組函數(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)容。