【问题标题】:Trying to Remove Nesting from Json Array in PHP尝试从 PHP 中的 Json 数组中删除嵌套
【发布时间】:2022-02-01 22:47:08
【问题描述】:

如您所见,我有一个包含多个元素的 json 数组,我一直在尝试删除嵌套(“DEMARCHE”)元素,我希望将数组展平。但它只给出一个输出数组,但我的 json 文件包含多个数组。 如果有人可以帮助我,我将非常感激。 _谢谢

** 这是输入**

[
    {
    "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":"",
    "DEMARCHE" : [
    {
    "DEMA_CODE":"08-93",
    "ANNEE_ADHESION":"2016",
    "RACE_MERES":"Limousine",
    "DESCRIPTIF_ATELIER":""
    }
    ]        
    },
    {
    "CHEPTEL":"12001",
    "NOM":"La Ferme ",
    "CODE_POSTAL":"12630",
    "VILLE":"AGEN D AVEYRON",
    "LATITUDE":"44.343518",
    "LONGITUDE":"2.716004",
    "DESCRIPTIF_FERME":"",
    "DEMARCHE" : [
    {
    "DEMA_CODE":"08-93",
    "ANNEE_ADHESION":"2016",
    "RACE_MERES":"Limousine",
    "DESCRIPTIF_ATELIER":""
    }
    ]        
    }
    ]

** 我希望输出是 **

[
    {
    "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":"",
    "DEMA_CODE":"08-93",
    "ANNEE_ADHESION":"2016",
    "RACE_MERES":"Limousine",
    "DESCRIPTIF_ATELIER":""     
    },
    {
    "CHEPTEL":"12001",
    "NOM":"La Ferme ",
    "CODE_POSTAL":"12630",
    "VILLE":"AGEN D AVEYRON",
    "LATITUDE":"44.343518",
    "LONGITUDE":"2.716004",
    "DESCRIPTIF_FERME":"",
    "DEMA_CODE":"08-93",
    "ANNEE_ADHESION":"2016",
    "RACE_MERES":"Limousine",
    "DESCRIPTIF_ATELIER":""       
    }
    ]

** 我的代码在这里**

<?php
   
    
    $array1 = json_decode($json,true);
    
    
    function array_flatten($array) {
    
       $return = array();
       foreach ($array as $key => $value) {
           if (is_array($value))
           { $return = array_merge($return, array_flatten($value));
                             }
           else {$return[$key] = $value;
                }
       }
       return $return;
    
    }
    
    $array  = $array1;
    
    $result = array_flatten($array);
    
    $jsonnew = json_encode($result);
    
    var_dump($jsonnew);
    
    
    ?>

【问题讨论】:

    标签: php json multidimensional-array nested-loops json-flattener


    【解决方案1】:

    只需循环并使用引用。

    //& sign in this context is called a reference.
    //That means the $original will be changed if $values is changed inside the loop.
    foreach($original as &$values) {
    
        $demarche = $values['DEMARCHE'];
        unset($values['DEMARCHE']);
    
        $values['DEMA_CODE'] = $demarche['DEMA_CODE'];
        $values['ANNEE_ADHESION'] = $demarche['ANNEE_ADHESION'];
        $values['RACE_MERES'] = $demarche['RACE_MERES'];
        $values['DESCRIPTIF_ATELIER'] = $demarche['DESCRIPTIF_ATELIER'];
    
        
    }
    

    结果:

    [
       {
          "CHEPTEL":"12001116",
          "NOM":"La Ferme de Jean-Marc et Aur\u00e9lien ",
          "CODE_POSTAL":"12630",
          "VILLE":"AGEN D AVEYRON",
          "LATITUDE":"44.343518",
          "LONGITUDE":"2.716004",
          "DESCRIPTIF_FERME":"",
          "DEMA_CODE":"08-93",
          "ANNEE_ADHESION":"2016",
          "RACE_MERES":"Limousine",
          "DESCRIPTIF_ATELIER":""
       },
       {
          "CHEPTEL":"12001",
          "NOM":"La Ferme ",
          "CODE_POSTAL":"12630",
          "VILLE":"AGEN D AVEYRON",
          "LATITUDE":"44.343518",
          "LONGITUDE":"2.716004",
          "DESCRIPTIF_FERME":"",
          "DEMA_CODE":"08-93",
          "ANNEE_ADHESION":"2016",
          "RACE_MERES":"Limousine",
          "DESCRIPTIF_ATELIER":""
       }
    ]
    

    【讨论】:

    • 您好,非常感谢您的回复。但它缺少 "DEMA_CODE":"08-93", "ANNEE_ADHESION":"2016", "RACE_MERES":"Limousine", "DESCRIPTIF_ATELIER":"" 是否有可能将它们也放入列表中?
    • @RanjitT 检查我的更新。
    【解决方案2】:

    试试这个:

    <?php
      $json = '[
        {
          "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":"",
          "DEMARCHE" : [
            {
            "DEMA_CODE":"08-93",
            "ANNEE_ADHESION":"2016",
            "RACE_MERES":"Limousine",
            "DESCRIPTIF_ATELIER":""
            }
          ]        
        },
        {
          "CHEPTEL":"12001",
          "NOM":"La Ferme ",
          "CODE_POSTAL":"12630",
          "VILLE":"AGEN D AVEYRON",
          "LATITUDE":"44.343518",
          "LONGITUDE":"2.716004",
          "DESCRIPTIF_FERME":"",
          "DEMARCHE" : [
            {
            "DEMA_CODE":"08-93",
            "ANNEE_ADHESION":"2016",
            "RACE_MERES":"Limousine",
            "DESCRIPTIF_ATELIER":""
            }
          ]        
        }
        ]';
        
      $array1 = json_decode($json, true);
      $newArr = array_map(function ($arr) {
        foreach ($arr as $key => $val) {
          if ($key === 'DEMARCHE') {
            foreach ($val[0] as $key1 => $val1) {
              $arr[$key1] = $val1;
            }
          }
        }
        
        unset($arr['DEMARCHE']);
        
        return $arr;
      }, $array1);
      
      echo json_encode($newArr, JSON_PRETTY_PRINT); // done!
    

    【讨论】:

    • 天啊!你是个天才。再次感谢您...
    • 我很乐意为您提供帮助。祝你好运!
    猜你喜欢
    • 1970-01-01
    • 2019-09-13
    • 2021-07-23
    • 1970-01-01
    • 2021-01-20
    • 2018-04-21
    • 1970-01-01
    • 2022-07-19
    • 1970-01-01
    相关资源
    最近更新 更多