Я пытаюсь преобразовать json-файл в формат csv, используя php-скрипт. Код выглядит следующим образом:
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"}
Выход, который я получаю, это: type, conversion, stream_type NON_ATTRIBUTED, Array, COOKIE NON_ATTRIBUTED, Array, COOKIE
Ожидаемый результат: тип, преобразование, значение_1, значение_3, значение_4, значение_5, stream_type NON_ATTRIBUTED, 000000100355321, XXXX, 1267, 6, COOKIE ..
Любая помощь оценивается, поскольку это для меня очень ново
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":{,