SimpleXMLElement::asXML
(PHP 5, PHP 7, PHP 8)
SimpleXMLElement::asXML — SimpleXML 要素に基づき整形式の XML 文字列を返す
説明
asXML
メソッドは、親オブジェクトのデータを
XML version 1.0 形式にフォーマットします。
パラメータ
filename
-
文字列を指定した場合、データを返すかわりにファイルにデータを書き込みます。
戻り値
filename
が指定されていない場合、この関数は
成功時に string 、エラー時に false
を返します。
パラメータが指定されていた場合は、ファイルが正常に書き込めたときに
true
、そうでないときに false
を返します。
変更履歴
バージョン | 説明 |
---|---|
8.0.0 |
filename は、nullable になりました。
|
例
例1 XML を取得する
<?php
$string = <<<XML
<a>
<b>
<c>text</c>
<c>stuff</c>
</b>
<d>
<c>code</c>
</d>
</a>
XML;
$xml = new SimpleXMLElement($string);
echo $xml->asXML();
?>
上の例の出力は以下となります。
<?xml version="1.0"?> <a> <b> <c>text</c> <c>stuff</c> </b> <d> <c>code</c> </d> </a>
asXML
は Xpath の結果にも適用できます:
例2 SimpleXMLElement::xpath() の結果に asXML() を使用する
<?php
// 上の XML の例から続く
/* <a><b><c>を探す */
$result = $xml->xpath('/a/b/c');
foreach ($result as $node) {
echo $node->asXML();
}
?>
上の例の出力は以下となります。
<c>text</c><c>stuff</c>
+add a note
User Contributed Notes 2 notes
andreas dot theissen at t-online dot de ¶
12 years ago
To prevent asXML from encoding vowels unwantedly, simply use an approriate XML header with encoding in advance.
If you do so, asXML will happily leave your vowels (and the header) entirely untouched.
<?php
$xmlstr =
'<?xml version="1.0" encoding="UTF-8"?>
<keys>
<key lang="en"><Insert></key>
<key lang="de"><Einfügen></key>
</keys>';
$sxe = new SimpleXMLElement($xmlstr);
$output = $sxe->asXML();
?>
$xmlstr and $output are identical now.
The subsequent use of html_entity_decode() (as proposed in the very beginning in another post) has several drawbacks:
1. It is slow
2. It is expensive
3. If there are already encoded arrow brackets or double quotes in your source for instance (as shown in the above example), markup will be broken.
oleg dot pavlin at gmail dot com ¶
12 years ago
Function asXML decodes special chars like ø, æ and others to æ, ø
To get normal output use without quoting:
$xml = html_entity_decode($xml, ENT_NOQUOTES, 'UTF-8');
↑ and ↓ to navigate •
Enter to select •
Esc to close
Press Enter without
selection to search using Google