
本文详解如何将两个结构相同的 json 数组(均为对象数组)按索引逐项合并,使每个对应位置的对象深度合并为一个新对象,并提供健壮、可复用的 php 实现方案。
在 PHP 开发中,常需将多个来源的 JSON 数据(如地理信息与业务属性)按逻辑顺序关联合并。典型场景是:一个数组包含农场基础信息($json1),另一个包含其运营属性($json2),二者元素一一对应(索引对齐),目标是生成单个增强型对象数组。
✅ 正确实现步骤
-
解码 JSON 字符串为 PHP 关联数组
使用 json_decode($json, true) 确保返回关联数组(而非对象),便于后续 array_merge() 操作:
$json1 = '[{"CHEPTEL":"12001116","NOM":"La Ferme de Jean-Marc et Aurélien ","CODE_POSTAL":"12630","VILLE":"AGEN D AVEYRON","LATITUDE":"44.343518","LONGITUDE":"2.716004","DESCRIPTIF_FERME":""},{"CHEPTEL":"12001","NOM":"La Ferme ","CODE_POSTAL":"12630","VILLE":"AGEN D AVEYRON","LATITUDE":"44.343518","LONGITUDE":"2.716004","DESCRIPTIF_FERME":""}]';
$json2 = '[{"DEMA_CODE":"08-93","ANNEE_ADHESION":"2016","RACE_MERES":"Limousine","DESCRIPTIF_ATELIER":""},{"DEMA_CODE":"08-93","ANNEE_ADHESION":"2016","RACE_MERES":"Limousine","DESCRIPTIF_ATELIER":""}]';
$data1 = json_decode($json1, true);
$data2 = json_decode($json2, true);-
按索引合并(推荐:foreach + array_merge)
遍历第一个数组,逐项与第二个数组同索引元素合并。array_merge() 会以右侧数组键值覆盖左侧同名键(若需深度递归合并,应改用 array_replace_recursive()):
$merged = [];
$length = min(count($data1), count($data2)); // 防止索引越界
for ($i = 0; $i < $length; $i++) {
$merged[] = array_merge($data1[$i], $data2[$i]);
}
// 转回 JSON(可选)
$resultJson = json_encode($merged, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
echo $resultJson;⚠️ 注意:原始答案中 $json1 和 $json2 被误当作已解码数组直接使用。实际必须先 json_decode(),否则会报错 Invalid argument supplied for foreach()。
-
增强版:支持不等长数组与错误处理
生产环境建议添加校验,避免因数组长度不一致导致数据丢失或崩溃:
if (!is_array($data1) || !is_array($data2)) {
throw new InvalidArgumentException('Invalid JSON input: must decode to arrays');
}
if (count($data1) !== count($data2)) {
error_log("Warning: Array lengths differ ({$data1} vs {$data2}). Merging only " . min(count($data1), count($data2)) . " items.");
}
$merged = [];
foreach ($data1 as $index => $item) {
if (isset($data2[$index]) && is_array($data2[$index])) {
$merged[$index] = array_merge($item, $data2[$index]);
} else {
$merged[$index] = $item; // 仅保留主数据
}
}? 关键注意事项
- 键名冲突处理:array_merge() 对重复键采用“后覆盖前”策略(如 $json2 中的 "DESCRIPTIF_ATELIER" 会覆盖 $json1 中同名空值)。若需保留左侧值,改用 array_replace()。
- JSON 编码安全:输出前务必检查 json_last_error(),确保无编码失败;生产环境启用 JSON_UNESCAPED_UNICODE 避免中文乱码。
-
性能提示:对超大数组(>10k 元素),可考虑 array_map() 替代循环,但可读性略低:
$merged = array_map(fn($a, $b) => array_merge($a, $b), $data1, $data2);
通过以上方法,你可高效、安全地完成二维 JSON 数组的索引级合并,适用于 API 数据聚合、报表生成等典型后端场景。











