我要导出到 XML 的 CSV 文件的字符集是 ASCII,所以它应该可以工作。
我认为该功能可能无法正确实现?不会抛出任何错误,但原始错误保持不变。
这是完整的错误代码:
致命错误:在 /home/paul/public_html/csv2xml.php:30 中未捕获的异常“DOMException”和消息“无效字符错误”堆栈跟踪:#0 /home/paul/public_html/csv2xml.php(30):DOMDocument-> createElement('Listdate (YYYY-...') #1 {main} 在第 30 行的 /home/paul/public_html/csv2xml.php 中抛出
<?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(htmlentities($header));
$child = $container->appendChild($child);
$value = $doc->createTextNode($row[$i]);
$value = $child->appendChild($value);
}
$root->appendChild($container);
}
echo $doc->saveXML();
?>