如何在 PHP 中合并两个二维 JSON 数组(按索引合并对象)

15次阅读

如何在 PHP 中合并两个二维 JSON 数组(按索引合并对象)

本文详解如何将两个结构相同的 json 数组(均为对象数组)按索引逐项合并,使每个对应位置的对象深度合并为一个新对象,并提供健壮、可复用的 php 实现方案。

php 开发中,常需将多个来源的 jsON 数据(如地理信息与业务属性)按逻辑顺序关联合并。典型场景是:一个数组包含农场基础信息($json1),另一个包含其运营属性($json2),二者元素一一对应(索引对齐),目标是生成单个增强型对象数组。

✅ 正确实现步骤

  1. 解码 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);
  1. 按索引合并(推荐: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()。

  1. 增强版:支持不等长数组与错误处理
    生产环境建议添加校验,避免因数组长度不一致导致数据丢失或崩溃:
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 数据聚合、报表生成等典型后端场景。

text=ZqhQzanResources