Вот коды:
$doc = new DomDocument('1.0'); // create root node $root = $doc->createElement('root'); $root = $doc->appendChild($root); $signed_values = array('a' => 'eee', 'b' => 'sd', 'c' => 'df'); // process one row at a time foreach ($signed_values as $key => $val) { // add node for each row $occ = $doc->createElement('error'); $occ = $root->appendChild($occ); // add a child node for each field foreach ($signed_values as $fieldname => $fieldvalue) { $child = $doc->createElement($fieldname); $child = $occ->appendChild($child); $value = $doc->createTextNode($fieldvalue); $value = $child->appendChild($value); } } // get completed xml document $xml_string = $doc->saveXML() ; echo $xml_string;
Если я распечатаю его в браузере, я не получаю хорошую структуру XML, как
<xml> \n tab <child> etc.
Я просто получаю
<xml><child>ee</child></xml>
И я хочу быть utf-8. Как это все можно сделать?
Вы можете попытаться сделать это:
... // get completed xml document $doc->preserveWhiteSpace = false; $doc->formatOutput = true; $xml_string = $doc->saveXML(); echo $xml_string;
Вы можете установить этот параметр сразу после создания DOMDocument
:
$doc = new DomDocument('1.0'); $doc->preserveWhiteSpace = false; $doc->formatOutput = true;
Это, вероятно, более кратким. Выход в обоих случаях: ( Demo ):
<?xml version="1.0"?> <root> <error> <a>eee</a> <b>sd</b> <c>df</c> </error> <error> <a>eee</a> <b>sd</b> <c>df</c> </error> <error> <a>eee</a> <b>sd</b> <c>df</c> </error> </root>
Я не знаю, как изменить отличительный DOMDocument
(ы) с помощью DOMDocument
. Вы можете выполнить пост-обработку XML с помощью линейной замены на основе регулярного выражения (например, с помощью preg_replace
):
$xml_string = preg_replace('/(?:^|\G) /um', "\t", $xml_string);
В качестве альтернативы, есть tidy extension с tidy_repair_string
который также может печатать XML-данные. Можно указать уровни отступов, но аккуратные никогда не будут выводить вкладки.
tidy_repair_string($xml_string, ['input-xml'=> 1, 'indent' => 1, 'wrap' => 0]);
С помощью объекта SimpleXml вы можете просто
$domxml = new DOMDocument('1.0'); $domxml->preserveWhiteSpace = false; $domxml->formatOutput = true; /* @var $xml SimpleXMLElement */ $domxml->loadXML($xml->asXML()); $domxml->save($newfile);
$xml
– ваш объект simplexml
Итак, вы можете просто сохранить файл как новый файл, указанный в файле $newfile
<?php $xml = $argv[1]; $dom = new DOMDocument(); // Initial block (must before load xml string) $dom->preserveWhiteSpace = false; $dom->formatOutput = true; // End initial block $dom->loadXML($xml); $out = $dom->saveXML(); print_R($out);
Здесь есть два разных вопроса:
Установите для атрибутов formatOutput и preserveWhiteSpace значение TRUE
для создания форматированного XML:
$doc->formatOutput = TRUE; $doc->preserveWhiteSpace = TRUE;
Многие веб-браузеры (а именно Internet Explorer и Firefox) форматируют XML при их отображении. Используйте функцию View Source или обычный текстовый редактор для проверки вывода.
См. Также xmlEncoding и encoding .
Это небольшая вариация вышеупомянутой темы, но я помещаю здесь, если другие попадают в нее и не могут ее понять … как и я.
При использовании saveXML () preserveWhiteSpace в целевом DOMdocument не применяется к импортированным узлам (как на PHP 5.6).
Рассмотрим следующий код:
$dom = new DOMDocument(); //create a document $dom->preserveWhiteSpace = false; //disable whitespace preservation $dom->formatOutput = true; //pretty print output $documentElement = $dom->createElement("Entry"); //create a node $dom->appendChild ($documentElement); //append it $message = new DOMDocument(); //create another document $message->loadXML($messageXMLtext); //populate the new document from XML text $node=$dom->importNode($message->documentElement,true); //import the new document content to a new node in the original document $documentElement->appendChild($node); //append the new node to the document Element $dom->saveXML($dom->documentElement); //print the original document
В этом контексте $dom->saveXML();
оператор НЕ будет печатать содержимое, импортированное из сообщения $, но контент изначально в $ dom будет довольно напечатан.
Чтобы добиться довольно полной печати всего документа $ dom, строка:
$message->preserveWhiteSpace = false;
должен быть включен после $message = new DOMDocument();
line – т.е. документ / с, из которого импортируются узлы, также должен иметь preserveWhiteSpace = false.
// ##### IN SUMMARY ##### $xmlFilepath = 'test.xml'; echoFormattedXML($xmlFilepath); /* * echo xml in source format */ function echoFormattedXML($xmlFilepath) { header('Content-Type: text/xml'); // to show source, not execute the xml echo formatXML($xmlFilepath); // format the xml to make it readable } // echoFormattedXML /* * format xml so it can be easily read but will use more disk space */ function formatXML($xmlFilepath) { $loadxml = simplexml_load_file($xmlFilepath); $dom = new DOMDocument('1.0'); $dom->preserveWhiteSpace = false; $dom->formatOutput = true; $dom->loadXML($loadxml->asXML()); $formatxml = new SimpleXMLElement($dom->saveXML()); //$formatxml->saveXML("testF.xml"); // save as file return $formatxml->saveXML(); } // formatXML