递归格式化JSON数据

要求:

有一个key=>value格式的数据,现在需要格式化将其输出,以key=value的形式输出,两个key=value直接用分号;隔开,如果value是数组的话,输出格式是这样的:key.item=value

例子:

{
    "person":{
        "name":"pig",
        "age":"18",
        "sex":"man",
        "hometown":{
            "province":"江西省",
            "city":"抚州市",
            "county":"崇仁县"
        }
    }
}

 

输出:

person.name=pig;person.age=18;person.sex=man;person.hometown.province=江西省;person.hometown.city=抚州市;person.hometown.county=崇仁县

 

分析:

由于是不确定层级的数据,所以普通的两个或者多个for循环遍历肯定是行不通的,这里考虑使用递归的方式进行处理

 

核心代码:

<?php
class Demo {
    public function printArray(array $data)
    {
        $result = $this->formatArray($data);
        echo substr($result, 0, -1);
    }

    public function formatArray($data, $prefix='')
    {
        if (is_array($data))
        {
            $result = '';
            foreach ($data as $key => $value)
            {
                $result .= $this->formatArray($value, empty($prefix)? "$key" : "$prefix.$key");
            }
            return $result;
        }
        else
        {
            return "$prefix=$data;";
        }
    }
}

 

下面用三个层级的数据测试一下:

<?php
$tmp = [
    'date' => '2020-01-01',
    'name' => 'name',
    'type' => 'type',
    'array1' => [
        'a' => '1',
        'b' => '2',
        'c' => '3',
    ],
    'price' => '1.0',
    'sum' => '2.0',
    'array2' => [
        'A' => '1',
        'B' => '2',
        'C' => [
            'C1' => '1',
            'C2' => '2',
            'C3' => [
                'C3_1' => '1',
                'C3_2' => '2',
                'C3_3' => '3',
            ],
        ],
    ],
    'count' => '12.0',
];

$demo = new Demo(); $demo->printArray($tmp);

 

输出:

date=2020-01-01;name=name;type=type;array1.a=1;array1.b=2;array1.c=3;price=1.0;sum=2.0;array2.A=1;array2.B=2;array2.C.C1=1;array2.C.C2=2;array2.C.C3.C3_1=1;array2.C.C3.C3_2=2;array2.C.C3.C3_3=3;count=12.0

 

总结:

1、由于不确定数据的层级,普通的循环遍历肯定是行不通的,即使知道了数据最多只有3个层次,也最好别写for循环处理,毕竟每一层的for循环你都要判断,代码会非常臃肿而且难维护

2、虽然递归很容易理解,但是也存在一些效率上的问题,这个需要谨慎使用,根据实际的生产环境数据多次测试,再选择合适的处理方法

 

posted @ 2020-05-10 11:45  凌雨尘  阅读(704)  评论(0编辑  收藏  举报