>  기사  >  백엔드 개발  >  PHP의 일반적인 배열 함수 요약(코드 예제 포함)

PHP의 일반적인 배열 함수 요약(코드 예제 포함)

藏色散人
藏色散人앞으로
2021-09-24 15:05:485497검색

1. 배열의 키 이름 및 값에 대한 일부 기본 작업 함수
1. 배열의 모든 키 또는 값 가져오기: array_keys() array_values() code><code>array_keys() array_values()

$arr_keys = array_keys($array);$arr_values = array_values($arr);

2.交换数组中键和值的位置,若重复前面的会被后面的覆盖:array_flip()

$arr2 = array_flip($arr);

3.给定的值是否在数组中:in_array(value,array)

$bool = in_array('hello',$arr);

4.在数组中搜索某个值,在则返回它的键,不在则返回FALSE:array_search()

$bool = array_search('hello',$arr);

5.给定键是否存在数组中:isset(array[key])array_key_exists(key,array)

$bool = array_key_exists('a',$arr);

6.获取数组元素的个数:count(array,mode),mode为1时表示递归地对数组进行计数,默认为0。别名sizeof()

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

7.将数组中的键名改为全小写或大写:array_change_key_case(array,case)。case有两个常用量:CASE_UPPERCASE_LOWER(默认值),即默认全小写

$lowarr = array_change_key_case($arr,CASE_LOWER);

8.统计数组中所有的值出现的次数:array_count_value(array)。返回一个数组,键是原数组的值,值是这个元素在原数组出现的次数

$arr_count = array_count_values($arr);

9.得到数组的第一个或最后一个键名:array_key_first(array)array_key_last(array)

$key = array_key_first($arr)

10.弹出数组的最后一个元素:

$last = array_pop($array);

将一个或多个单元压入数组的末尾或数组的开头,并返回新数组的个数:

$new_array = array_push($array,$value1,$value2,...);$new_array = array_unshift($array,$value1,$value2,...);

11.将数组反序:array_reverse(array)

$reverse = array_reverse($arr)

12.对数组中所有值求和或求乘积:

$sum = array_sum($array);$product = array_product($array);

13.去除数组中重复的值:

array_unique($array,,SORT_STRING);sort_falgs参数用于修改排序行为:SORT_NUMERIC - 按照数字形式比较、SORT_STRING - 按照字符串形式比较

14.打乱数组:shuffle(array)

$bool = shuffle($arr);

15.从数组中随机取得一个或多个键名:array_rand(array,num=1),返回包含随机键名的数组。

二、数组的一些关于创建和分割的操作函数总结
1.将一个数组分割成多个数组:array_chunk(array,size,preserve_keys)
参数:
size:指明每个数组的元素个数
preserve_keys:指明是否保留原来的键名,默认为false
函数返回一个二维数组

$myarr = array_chunk($arr,2)

2.创建一个数组,用一个数组的值作为其键名,另一个数组的值作为其值:array_combine(keys,values)

$arr_1 = ['A','B','C'];$arr_2 = ['a','b','c'];$arr_3 = array_combine($arr_1,$arr_2);

3.使用指定的键和值填充数组:array_fill_keys(keys,value)

$keys = array('foo', 5, 10, 'bar');$a = array_fill_keys($keys, 'banana');

4.用给定的值填充数组:array_fill(start_index,num,value)
参数:
start_index:数组的第一个索引
num:插入元素的数量,即数组的长度,必须为非负数
value:用来填充的值

$arr = array_fill(0,10,'myname');

5.合并一个或多个数组:array_merge(array1,array2...)
键名相同时,若是字符键名则会被覆盖,数字键名则不会被覆盖,而是附加到后面

$a = array_merge($arr_1,$arr_2);

6.递归的合并一个或多个数组:array_merge_recursive(array_1,array_2,...)
如果数组具有相同的数组键名,后一个值将不会覆盖原来的值,而是附加到后面.

7.以指定长度将一个值填充进数组:array_pad(array,size,value)
参数:
size:填充后数组的长度,为正则填充到数组的右侧,为负则填充到数组的左侧
value:用来填充的值

8.从数组中取出一段:array_slice(array,offset,length,preserve_keys)
参数:
offset:开始的偏移量,正负皆可
length:取得的长度,正数表示取得元素的个数,负数表示距离数组末尾的距离
preserve_keys:是否保留原来的键名

10.去掉数组中的某一部分并用其它值取代:array_splice(array,offset,length,replacement_array)
参数:
replacement_array:移除的单元被此数组中的单元替代

11.使用变量创建数组:compact(var1,var2,...),变量名为键名,变量值为元素的值

12.从数组中导出变量:extract(array),键名为变量名,值为变量的值

13.把数组的值赋予变量:list(var1,var2,...)

list($drink, , $power) = array('coffee', 'brown', 'caffeine');

14.根据范围创建数组,包含指定的元素:range(start,end,step)

range(0,8,2) ==> [0,2,4,6,8]
2 .배열에서 키와 값의 위치를 ​​교환합니다. 이전 항목이 반복되면 다음 항목으로 덮어쓰게 됩니다:array_flip()🎜
/*bool sort ( array &$array [, int $sort_flags = SORT_REGULAR ] )SORT_REGULAR参数可以用以下值改变排序的行为:SORT_REGULAR - 正常比较单元(不改变类型)SORT_NUMERIC - 单元被作为数字来比较SORT_STRING - 单元被作为字符串来比较SORT_LOCALE_STRING - 根据当前的区域(locale)设置来把单元当作字符串比较,可以用 setlocale() 来改变。SORT_NATURAL - 和 natsort() 类似对每个单元以“自然的顺序”对字符串进行排序。 PHP 5.4.0 中新增的。SORT_FLAG_CASE - 能够与 SORT_STRING 或 SORT_NATURAL 合并(OR 位运算),不区分大小写排序字符串。 */
🎜3 . 주어진 값이 배열에 있는지 여부:in_array(value ,array)🎜
2.sort()、rsort():对值进行升序和降序的排序3.ksort()、krsort():对键名进行升序和降序的排序4.asort()、arsort():保持索引关系的同时,对值进行升序和降序的排序5.usort()、uksort()、uasort():使用自定义的排序函数,进行按值的升序排序、按键名的升序排序、保持索引关系的升序排序6.natsort():使用自然排序算法对数组进行排序7.natcasesort():使用自然排序算法对数组进行不区分大小写字母的排序
🎜4. 배열에서 값을 검색하고 해당 값이 있으면 해당 키를 반환하고, 그렇지 않으면 FALSE를 반환합니다. >array_search()🎜
array_intersect()                     使用数据进行交集比较array_uintersect()                    使用数据进行交集比较,但是自定义函数比较array_intersect_key()                 使用键名进行交集比较array_intersect_ukey()                使用键名进行交比较,但是自定义函数比较array_intersect_assoc()               同时使用数据和键名array_intersect_uassoc()              同时使用数据和键名,但是键名使用自定义函数比较array_uintersect_assoc()              同时使用数据和键名,但是数据使用自定义函数比较array_uintersect_uassoc()             同时使用数据和键名,都使用自定义函数
🎜5. 키가 배열에 존재하는지 여부: isset(array[key])array_key_exists(key, array)🎜rrreee🎜6. 배열 요소 수를 가져옵니다: count( array, mode), 모드가 1이면 배열을 재귀적으로 계산한다는 의미이며 기본값은 0입니다. 별칭 ​​sizeof()🎜rrreee🎜7. 배열의 키 이름을 모두 소문자 또는 대문자로 변경합니다(array_change_key_case(array,case)). Case에 일반적으로 사용되는 두 가지 변수는 CASE_UPPER 또는 CASE_LOWER(기본값)이며 기본적으로 모두 소문자입니다🎜rrreee🎜8. 모든 값의 발생 횟수를 계산합니다. ​​배열에서: array_count_value(array). 배열을 반환합니다. 키는 원래 배열의 값이고, 값은 이 요소가 원래 배열에 나타나는 횟수입니다🎜rrreee🎜9. 배열의 첫 번째 또는 마지막 키 이름을 가져옵니다: array_key_first(array) ), array_key_last(array)🎜rrreee🎜10. 배열의 마지막 요소를 팝합니다.🎜rrreee🎜 하나 이상의 셀을 배열의 끝이나 배열의 시작 부분에 밀어 넣습니다. , 그리고 새로운 배열의 수를 반환합니다:🎜 rrreee🎜11. 배열을 뒤집습니다: array_reverse(array)🎜rrreee🎜12. 배열의 모든 값을 합산하거나 곱합니다:🎜rrreee🎜13 . 배열에서 중복 값 제거:🎜rrreee 🎜14. 배열 섞기: shuffle(array)🎜rrreee🎜15 배열에서 하나 이상의 키 이름을 무작위로 얻습니다: array_rand (array,num=1) 는 임의의 키 이름이 포함된 배열을 반환합니다. 🎜🎜2. 배열 생성 및 분할과 관련된 일부 작업 함수 요약🎜1. 배열을 여러 배열로 분할: array_chunk(array,size,preserve_keys)🎜 : 🎜size: 각 배열의 요소 수를 지정합니다. 🎜preserve_keys: 원래 키 이름을 유지할지 여부를 지정합니다. 기본값은 false입니다. 🎜함수는 2차원 배열을 반환합니다🎜rrreee🎜2. 한 배열의 값을 키 이름으로 사용하고 다른 배열의 값을 해당 값으로 사용하여 배열을 만듭니다. array_combine(keys,values)🎜rrreee 🎜3. 지정된 키와 값으로 배열을 채웁니다: array_fill_keys(keys,value)🎜rrreee🎜4. 지정된 값으로 배열을 채웁니다: array_fill(start_index,num) ,value)🎜매개변수: 🎜<code>start_index: 배열의 첫 번째 인덱스 🎜num: 삽입된 요소의 수, 즉 배열의 길이 , 음수가 아니어야 합니다. 🎜: 채우는 데 사용되는 값🎜rrreee🎜5. 하나 이상의 배열을 병합합니다: array_merge(array1,array2...) 🎜키 이름이 동일할 때 문자 키 이름이면 덮어쓰지만 숫자 키 이름은 덮어쓰지 않고 끝에 추가됩니다🎜rrreee🎜6. 하나 이상의 배열을 재귀적으로 병합합니다. array_merge_recursive(array_1,array_2,...)🎜 배열의 배열 키 이름이 동일한 경우 후자의 값이 원래 값을 덮어쓰지 않고 추가됩니다. 🎜🎜7. 지정된 길이의 배열에 값: array_pad(array,size,value )🎜매개변수: 🎜size: 채운 후 배열의 길이입니다. , 배열의 오른쪽에 채워지고, 음수이면 배열의 왼쪽에 채워집니다🎜: 채우는 데 사용되는 값🎜🎜 8. 세그먼트를 가져옵니다. 배열에서: array_slice(array,offset,length,preserve_keys)🎜매개변수: 🎜offset: 시작 오프셋 이동량은 양수 또는 음수일 수 있습니다🎜length: 얻은 길이, 양수는 얻은 요소 수, 음수는 배열 끝으로부터의 거리를 나타냅니다.🎜<code>preserve_keys: 원본을 유지할지 여부 키 이름🎜🎜 10. 배열의 특정 부분을 제거하고 다른 값으로 교체합니다: array_splice(array,offset,length,replacement_array)🎜매개변수:🎜replacement_array: 제거 단위는 다음과 같습니다. 이 배열의 단위로 대체됩니다🎜🎜11. 변수를 사용하여 배열을 만듭니다: compact(var1,var2,...), 변수 이름은 키 이름이고 변수 값은 값입니다. of the element🎜🎜 12. 배열에서 변수 내보내기: extract(array), 키는 변수 이름이고 값은 변수의 값입니다🎜🎜13. 변수에 대한 배열: list(var1,var2 ,...)🎜rrreee🎜14. 지정된 요소를 포함하는 범위를 기반으로 배열을 만듭니다: range(start,end,step )🎜
range(0,8,2) ==> [0,2,4,6,8]

三、数组排序基本函数名为 sort
可以添加其他拓展:r表示逆向排序,k表示对键名进行排序,a表示保持索引关系,u表示用自定义的函数进行比较 1.详细介绍sort函数的情况,其他的函数类似

/*bool sort ( array &$array [, int $sort_flags = SORT_REGULAR ] )SORT_REGULAR参数可以用以下值改变排序的行为:SORT_REGULAR - 正常比较单元(不改变类型)SORT_NUMERIC - 单元被作为数字来比较SORT_STRING - 单元被作为字符串来比较SORT_LOCALE_STRING - 根据当前的区域(locale)设置来把单元当作字符串比较,可以用 setlocale() 来改变。SORT_NATURAL - 和 natsort() 类似对每个单元以“自然的顺序”对字符串进行排序。 PHP 5.4.0 中新增的。SORT_FLAG_CASE - 能够与 SORT_STRING 或 SORT_NATURAL 合并(OR 位运算),不区分大小写排序字符串。 */

排序函数分类大致如下:

2.sort()、rsort():对值进行升序和降序的排序3.ksort()、krsort():对键名进行升序和降序的排序4.asort()、arsort():保持索引关系的同时,对值进行升序和降序的排序5.usort()、uksort()、uasort():使用自定义的排序函数,进行按值的升序排序、按键名的升序排序、保持索引关系的升序排序6.natsort():使用自然排序算法对数组进行排序7.natcasesort():使用自然排序算法对数组进行不区分大小写字母的排序

四、数组运算
数组差集的计算 u表示用自定义的回调函数,diff表示用数据做差集,assoc表示用索引做差集

1.计算数组的差集:array_diff(array1,array2,...) 对比array1和其他数组,返回在array1中但不在其他数组中的值。返回一个数组,但是键名不保留

2.用回调函数比较数据来计算数组的差集:array_udiff(arr1,arr2,...,value_cpmpare_func)
使用用户自定义的函数进行数据比较,而不是内置的函数。

3.使用键名比较计算数组的差集:array_diff_key(array1,array2,...)
使用键名而不是值来进行差集计算

4.用回调函数对键名比较计算数组的差集:array_diff_ukey(arr1,arr2,...,key_compare_func)

5.带索引检查计算数组的差集:array_diff_assoc(array1,array2,..)
同时使用键名和值来进行差集计算

6.带索引检查计算数组的差集,用回调函数比较索引:array_diff_uassoc(arr1,arr2,...,key_compare_func)
key_compare_func:用户自定义的用于比较键名的函数。

7.带索引检查计算数组的差集,用回调函数比较数据:array_udiff_assoc(arr1,arr2,...,value_cpmpare_func)
value_cpmpare_func:用户自定义的用于比较数据的函数

8.用回调函数比较数据和索引,计算数组的差集:array_udiff_uassoc(arr1,arr2,...,value_cpmpare_func,key_compare_func)

数组交集的计算 同差集一样,也有8个函数:

array_intersect()                     使用数据进行交集比较array_uintersect()                    使用数据进行交集比较,但是自定义函数比较array_intersect_key()                 使用键名进行交集比较array_intersect_ukey()                使用键名进行交比较,但是自定义函数比较array_intersect_assoc()               同时使用数据和键名array_intersect_uassoc()              同时使用数据和键名,但是键名使用自定义函数比较array_uintersect_assoc()              同时使用数据和键名,但是数据使用自定义函数比较array_uintersect_uassoc()             同时使用数据和键名,都使用自定义函数

推荐学习:《PHP视频教程

위 내용은 PHP의 일반적인 배열 함수 요약(코드 예제 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 learnku.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제