溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

PHP常見數(shù)組函數(shù)有哪些以及其代碼怎么寫

發(fā)布時間:2021-09-24 16:44:22 來源:億速云 閱讀:147 作者:柒染 欄目:編程語言

PHP常見數(shù)組函數(shù)有哪些以及其代碼怎么寫,針對這個問題,這篇文章詳細介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

                           

一、數(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ù)組進行計數(shù),默認為0。別名sizeof()

$n = count($arr);  //等價于:$n = sizeof($arr);

7.將數(shù)組中的鍵名改為全小寫或大寫:array_change_key_case(array,case)。case有兩個常用量:CASE_UPPERCASE_LOWER(默認值),即默認全小寫

$lowarr = array_change_key_case($arr,CASE_LOWER);

8.統(tǒng)計數(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ù)組中隨機取得一個或多個鍵名:array_rand(array,num=1),返回包含隨機鍵名的數(shù)組。

二、數(shù)組的一些關(guān)于創(chuàng)建和分割的操作函數(shù)總結(jié)
1.將一個數(shù)組分割成多個數(shù)組:array_chunk(array,size,preserve_keys)
參數(shù):
size:指明每個數(shù)組的元素個數(shù)
preserve_keys:指明是否保留原來的鍵名,默認為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ù)組的長度,必須為非負數(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.以指定長度將一個值填充進數(shù)組:array_pad(array,size,value)
參數(shù):
size:填充后數(shù)組的長度,為正則填充到數(shù)組的右側(cè),為負則填充到數(shù)組的左側(cè)
value:用來填充的值

8.從數(shù)組中取出一段:array_slice(array,offset,length,preserve_keys)
參數(shù):
offset:開始的偏移量,正負皆可
length:取得的長度,正數(shù)表示取得元素的個數(shù),負數(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表示對鍵名進行排序,a表示保持索引關(guān)系,u表示用自定義的函數(shù)進行比較 1.詳細介紹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ù)當前的區(qū)域(locale)設(shè)置來把單元當作字符串比較,可以用 setlocale() 來改變。SORT_NATURAL - 和 natsort() 類似對每個單元以“自然的順序”對字符串進行排序。 PHP 5.4.0 中新增的。SORT_FLAG_CASE - 能夠與 SORT_STRING 或 SORT_NATURAL 合并(OR 位運算),不區(qū)分大小寫排序字符串。 */

排序函數(shù)分類大致如下:

2.sort()、rsort():對值進行升序和降序的排序3.ksort()、krsort():對鍵名進行升序和降序的排序4.asort()、arsort():保持索引關(guān)系的同時,對值進行升序和降序的排序5.usort()、uksort()、uasort():使用自定義的排序函數(shù),進行按值的升序排序、按鍵名的升序排序、保持索引關(guān)系的升序排序6.natsort():使用自然排序算法對數(shù)組進行排序7.natcasesort():使用自然排序算法對數(shù)組進行不區(qū)分大小寫字母的排序

四、數(shù)組運算
數(shù)組差集的計算 u表示用自定義的回調(diào)函數(shù),diff表示用數(shù)據(jù)做差集,assoc表示用索引做差集

1.計算數(shù)組的差集:array_diff(array1,array2,...) 對比array1和其他數(shù)組,返回在array1中但不在其他數(shù)組中的值。返回一個數(shù)組,但是鍵名不保留

2.用回調(diào)函數(shù)比較數(shù)據(jù)來計算數(shù)組的差集:array_udiff(arr1,arr2,...,value_cpmpare_func)
使用用戶自定義的函數(shù)進行數(shù)據(jù)比較,而不是內(nèi)置的函數(shù)。

3.使用鍵名比較計算數(shù)組的差集:array_diff_key(array1,array2,...)
使用鍵名而不是值來進行差集計算

4.用回調(diào)函數(shù)對鍵名比較計算數(shù)組的差集:array_diff_ukey(arr1,arr2,...,key_compare_func)

5.帶索引檢查計算數(shù)組的差集:array_diff_assoc(array1,array2,..)
同時使用鍵名和值來進行差集計算

6.帶索引檢查計算數(shù)組的差集,用回調(diào)函數(shù)比較索引:array_diff_uassoc(arr1,arr2,...,key_compare_func)
key_compare_func:用戶自定義的用于比較鍵名的函數(shù)。

7.帶索引檢查計算數(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ù)和索引,計算數(shù)組的差集:array_udiff_uassoc(arr1,arr2,...,value_cpmpare_func,key_compare_func)

數(shù)組交集的計算 同差集一樣,也有8個函數(shù):

array_intersect()                     使用數(shù)據(jù)進行交集比較array_uintersect()                    使用數(shù)據(jù)進行交集比較,但是自定義函數(shù)比較array_intersect_key()                 使用鍵名進行交集比較array_intersect_ukey()                使用鍵名進行交比較,但是自定義函數(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ù)

關(guān)于PHP常見數(shù)組函數(shù)有哪些以及其代碼怎么寫問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI