Просто интересно, может ли кто-нибудь указать мне в сторону некоторых советов / сценариев, которые помогут мне создать XML из исходного файла CSV, используя PHP.
ура
Это довольно просто сделать, просто взгляните на fgetcsv, чтобы читать файлы csv, а затем DomDocument, чтобы написать xml-файл. Эта версия использует заголовки из файла в качестве ключей документа xml.
<?php error_reporting(E_ALL | E_STRICT); ini_set('display_errors', true); ini_set('auto_detect_line_endings', true); $inputFilename = 'input.csv'; $outputFilename = 'output.xml'; // Open csv to read $inputFile = fopen($inputFilename, 'rt'); // Get the headers of the file $headers = fgetcsv($inputFile); // Create a new dom document with pretty formatting $doc = new DomDocument(); $doc->formatOutput = true; // Add a root node to the document $root = $doc->createElement('rows'); $root = $doc->appendChild($root); // Loop through each row creating a <row> node with the correct data while (($row = fgetcsv($inputFile)) !== FALSE) { $container = $doc->createElement('row'); foreach($headers as $i => $header) { $child = $doc->createElement($header); $child = $container->appendChild($child); $value = $doc->createTextNode($row[$i]); $value = $child->appendChild($value); } $root->appendChild($container); } $strxml = $doc->saveXML(); $handle = fopen($outputFilename, "w"); fwrite($handle, $strxml); fclose($handle);
Приведенный выше код создает XML-документ, но не сохраняет его на любом физическом устройстве. Поэтому замените echo $doc->saveXML();
с
$strxml = $doc->saveXML(); $handle = fopen($outputFilename, "w"); fwrite($handle, $strxml); fclose($handle);
Есть несколько сайтов, которые будут делать это за вас .
Если это будет обычный процесс, а не одноразовый, это может быть идеальным для простого анализа CSV и вывода XML:
$csv = file("path/to/csv.csv"); foreach($csv as $line) { $data = explode(",", $line); echo "<xmltag>".$data[0]."</xmltag>"; //etc... }
Просмотрите file
PHP и string
функции.