php数组相加 数组合并 array_merge() 函数

zblog2年前zblog问题解答55

在 PHP 中,当你说“数组相加”时,这通常指的是将两个数组合并成一个新的数组。但是,因为数组可以是索引数组(数字键)或关联数组(字符串键),所以合并数组的方法会有所不同。

以下是几种合并数组的常见方法:

  1. 使用 + 运算符(仅适用于数字索引数组,且不会覆盖重复的键):

$array1 = [1, 2, 3];
$array2 = [4, 5, 6];
$result = $array1 + $array2; 

// 结果为 [1, 2, 3, 4, 5, 6],但只合并到 $array1 的长度

注意:+ 运算符的行为是,如果存在相同的键,则只保留第一个数组中的值。而且,如果 $array2 的长度大于 $array1,那么超出 $array1 长度的部分将被忽略。

  1. 使用 array_merge() 函数(适用于数字索引和关联数组,且会覆盖重复的键)

image.png

php复制代码

$array1 = ['a' => 1, 'b' => 2];

$array2 = ['b' => 3, 'c' => 4];

$result = array_merge($array1, $array2); // 结果为 ['a' => 1, 'b' => 3, 'c' => 4]  



// 对于数字索引数组  

$array1 = [1, 2, 3];

$array2 = [4, 5, 6];

$result = array_merge($array1, $array2); // 结果为 [1, 2, 3, 4, 5, 6],键被重新索引

array_merge() 函数会合并两个或多个数组为一个数组,如果输入数组中有相同的字符串键名,则后面的值将覆盖前面的值;如果数组是数字索引的,则后面的值将不会覆盖原来的值,而是附加到后面。

  1. 使用 array_merge_recursive() 函数(对于关联数组,它会将具有相同键的值合并为一个数组):

php复制代码$array1 = ['a' => 1, 'b' => 2];$array2 = ['b' => [3, 4], 'c' => 5];$result = array_merge_recursive($array1, $array2); // 结果为 ['a' => 1, 'b' => [2, 3, 4], 'c' => 5]

注意:这里 'b' 键的值被合并为一个数组 [2, 3, 4],这并不是通常期望的结果。

  1. 使用 ... 运算符(PHP 5.6+)(与 array_merge() 功能相似):

    image.png




php复制代码

$array1 = [1, 2, 3];

$array2 = [4, 5, 6];

$result = [...$array1, ...$array2]; // 结果为 [1, 2, 3, 4, 5, 6],键被重新索引  



$array1 = ['a' => 1, 'b' => 2];

$array2 = ['b' => 3, 'c' => 4];

$result = [...$array1, ...$array2]; // 注意:这不会按期望合并关联数组,而是会创建新的数字索引数组



对于关联数组,使用 ... 运算符可能不会得到你期望的结果,因为它不会处理重复的键,而是将它们作为新元素添加到数组中(并创建新的数字索引)。

根据你的具体需求,选择适当的合并方法。如果你只是想简单地合并两个数组并保留所有值(不考虑键的重复),array_merge() 可能是最常用的方法。


相关文章

phpstorm中的正则表达式替换 编辑器IDE

phpstorm中的正则表达式替换 编辑器IDE

phpstorm中的正则表达式替换 编辑器IDE...

Storage engine MylSAM is disabled (Table creation is disallowed). mysql8++  MyISAM 或 InnoDB(8默认)数据库

Storage engine MylSAM is disabled (Table creation is disallowed). mysql8++ MyISAM 或 InnoDB(8默认)数据库

Storage engine MylSAM is disabled (Table creation is disallowed). mysql8++  MyISAM 或 InnoDB(8默认...

ZBLOG定义系统常、变量 用户级别 定义文章类型 定义文章状态

<?php /*zb_system/function/c_system_defined.php  * 定义系统常、变量  */ /*  *&...

real_escape_string mysql处理特殊字符函数替换单引号等的函数 real_escape_string

$conn->real_escape_string($city);$conn->real_escape_string($city);real_escape_string...

CIDR / IP地址 / 子网地址 子网掩码 的例子(子网地址是什么?掩码是什么? 判断一个 IPv4 地址是否在指定的 CIDR 子网内 获取用户真实IP的PHP实现(可能会造假))

IP地址 = 8位.8位.8位.8位  (一个字节8位 ,每个位是0或1,8位bit转为十进制就是 0-255)192.168.5.0/24 这个称为子网地址或子网,其中24是掩码。掩码是从...

ZBLOG 获取表字段名字

global $zbp;     $fieldID = $zbp->datainfo['Post'][&#...