【问题标题】:Converting JSON to CSV format using PHP使用 PHP 将 JSON 转换为 CSV 格式
【发布时间】:2013-12-18 20:07:26
【问题描述】:

我正在尝试使用 php 脚本将 json 文件转换为 csv 格式。代码如下:

if (empty($argv[1])) die("The json file name or URL is missed\n");
$jsonFilename = $argv[1];

$json = file_get_contents($jsonFilename);
$array = json_decode($json, true);
$f = fopen('output.csv', 'w');

$firstLineKeys = false;
foreach ($array as $line)
{
    if (empty($firstLineKeys))
    {
            $firstLineKeys = array_keys($line);
            fputcsv($f, $firstLineKeys);
            $firstLineKeys = array_flip($firstLineKeys);
    }

fputcsv($f, array_merge($firstLineKeys, $line));

}

这种方法有效,但只返回 JSON 文件的外部变量,并且收到“数组到字符串转换”警告

JSON 数据如下所示:

{"type":"NON_ATTRIBUTED","conversion":{,"value_1":"000000100355321","value_3":"XXXX","value_4":"12667","value_5":"6"},"stream_type":"COOKIE"}
{"type":"ATTRIBUTED","conversion":{,"value_1":"000000167865321","value_3":"YYYY","value_4":"12668","value_5":"0"},"stream_type":"COOKIE"}
{"type":"NON_ATTRIBUTED","conversion":{,"value_1":"000000134535321","value_3":"AAAA","value_4":"12669","value_5":"9"},"stream_type":"COOKIE"}
{"type":"NON_ATTRIBUTED","conversion":{,"value_1":"000000100357651","value_3":"WWWW","value_4":"12670","value_5":"2"},"stream_type":"COOKIE"}

我得到的输出是: 类型,转换,stream_type NON_ATTRIBUTED,数组,COOKIE NON_ATTRIBUTED,Array,COOKIE

我期望的输出是: 类型,转换,value_1,value_3,value_4,value_5,stream_type NON_ATTRIBUTED,000000100355321, XXXX, 1267, 6, COOKIE ..

感谢任何帮助,因为这对我来说很新

【问题讨论】:

    标签: php json


    【解决方案1】:

    json_decode($json, true);将 JSON 对象转换为关联数组。所以这个

    {
        "type":"NON_ATTRIBUTED",
        "conversion":{,
            "value_1":"000000100355321",
            "value_3":"XXXX",
            "value_4":"12667",
            "value_5":"6"
        },
        "stream_type":"COOKIE"
    }
    

    变成这样:

    array(3) { 
        ["type"]=> string(14) "NON_ATTRIBUTED" 
        ["conversion"]=> array(4) { 
            ["value_1"]=> string(15) "000000100355321" 
            ["value_3"]=> string(4) "XXXX" 
            ["value_4"]=> string(5) "12667" 
            ["value_5"]=> string(1) "6" 
        } 
        ["stream_type"]=> string(6) "COOKIE" 
    }
    

    如您所见,存在嵌套数组。并且您尝试使用以下行将数组的所有元素插入到您的文本文件(csv 只是一个简单的文本文件):

    fputcsv($f, array_merge($firstLineKeys, $line));
    

    当数组元素是字符串时效果很好。但是当元素是数组时,我们得到了数组到字符串的转换。所以你必须在嵌套数组上使用 loop 或 array_merge 来防止这种情况发生。

    我无法清楚地理解您的 csv 应该是什么样子,但我希望您的代码修复对您有所帮助。如果没有,请在下面写评论。

    if (empty($argv[1])) die("The json file name or URL is missed\n");
    $jsonFilename = $argv[1];
    
    $json = file_get_contents($jsonFilename);
    $array = json_decode($json, true);
    $f = fopen('output.csv', 'w');
    
    $firstLineKeys = false;
    foreach ($array as $line)
    {
        if (empty($firstLineKeys))
        {
            $firstLineKeys = array_keys($line);
            fputcsv($f, $firstLineKeys);
            $firstLineKeys = array_flip($firstLineKeys);
        }
        $line_array = array($line['type']);
        foreach ($line['conversion'] as $value)
        {
            array_push($line_array,$value);
        }
        array_push($line_array,$line['stream_type']);
        fputcsv($f, $line_array);
    
    }
    

    您的 json 中还有一个错误 - 不需要的逗号:"conversion":{,

    【讨论】:

    • 这太完美了!非常感谢:)
    • @Applejack 对于if(empty($firstLineKeys))$firstLineKeys 必须为真,因此为空,if 循环中的语句才能运行?
    • @pHorseSpec 这行与问题本身无关,所以我没有更改它。如果您需要将一些 JSON 转换为 CSV,您应该首先确定 CSV 文件的结构,因为 JSON 和 CSV 是不同的数据结构:JSON 是树,CSV 是表。 Topic 开始构建自己的结构,但他的代码和 JSON 文件中存在错误,所以我所做的只是修复它。
    • 有没有可能将多维树结构json格式转换成CSV格式??
    • @SiddharthChoudhary 如果您有任何问题 - 请在此处提问,以便每个人都可以做出贡献。
    猜你喜欢
    • 1970-01-01
    • 2020-08-25
    • 2015-03-26
    • 1970-01-01
    • 2023-04-02
    • 1970-01-01
    • 1970-01-01
    • 2013-11-07
    相关资源
    最近更新 更多