[英]Error convert .CSV to .XML using PHP Script
我正在尝试将CSV文件转换为XML,以导入到PrestaShop中。 我正在使用从帖子中获得的以下脚本。 但这不起作用。
function createXML(){
error_reporting(E_ALL | E_STRICT);
ini_set('display_errors', true);
ini_set('auto_detect_line_endings', true);
$inputFilename = 'import/products_import.csv';
$outputFilename = 'import/productos.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(trim($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);
echo ('ejecutado');
}
我得到的错误是这样的:
致命错误:未捕获的DOMException:C:\\ xampp \\ htdocs \\ prestashop-devel \\ admin \\ productsImportWS.php:52中的无效字符错误#0 C:\\ xampp \\ htdocs \\ prestashop-devel \\ admin \\ productsImportWS.php( 52):DOMDocument-> createElement('Product ID; Acti ...')#1 C:\\ xampp \\ htdocs \\ prestashop-devel \\ admin \\ productsImportWS.php(73):createXML()#2 {main}被抛出C:\\ xampp \\ htdocs \\ prestashop-devel \\ admin \\ productsImportWS.php在第52行
我试图“修剪”页眉,但无法正常工作...
除非&
转换为&
否则&
字符将破坏您的XML &
$fixed = htmlspecialchars('&'); // output &
响应:
显然,“ fgetcsv”具有预定义的分隔符类型,在这种情况下为“,”。 具有CSV,以“;”分隔 它没有检测到它。
我在使用分隔符的两行中定义了分隔符,如下所示:
$headers = fgetcsv($inputFile, '0', ';');
while (($row = fgetcsv($inputFile, '0', ';')) !== FALSE)
这样,一切正常。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.