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_UPPER
或CASE_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]
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 位运算),不区分大小写排序字符串。 */
in_array(value ,array)
🎜2.sort()、rsort():对值进行升序和降序的排序3.ksort()、krsort():对键名进行升序和降序的排序4.asort()、arsort():保持索引关系的同时,对值进行升序和降序的排序5.usort()、uksort()、uasort():使用自定义的排序函数,进行按值的升序排序、按键名的升序排序、保持索引关系的升序排序6.natsort():使用自然排序算法对数组进行排序7.natcasesort():使用自然排序算法对数组进行不区分大小写字母的排序
array_intersect() 使用数据进行交集比较array_uintersect() 使用数据进行交集比较,但是自定义函数比较array_intersect_key() 使用键名进行交集比较array_intersect_ukey() 使用键名进行交比较,但是自定义函数比较array_intersect_assoc() 同时使用数据和键名array_intersect_uassoc() 同时使用数据和键名,但是键名使用自定义函数比较array_uintersect_assoc() 同时使用数据和键名,但是数据使用自定义函数比较array_uintersect_uassoc() 同时使用数据和键名,都使用自定义函数
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!