Ответ 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));
Хорошо работает, когда элемент массива является строкой. Но когда элемент является массивом, мы получили преобразование Array в строку. Поэтому вы должны использовать 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":{,