simplexml_import_dom

(PHP 5, PHP 7, PHP 8)

simplexml_import_domXML または HTML ノードから SimpleXMLElement オブジェクトを取得する

説明

simplexml_import_dom(object $node, ?string $class_name = SimpleXMLElement::class): ?SimpleXMLElement

この関数は、DOM ドキュメントのノードを引数とし、 SimpleXML ノードを作成します。この新しいオブジェクトは、 この後、通常の SimpleXML 要素として使用できます。

パラメータ

node

DOM 要素ノード。

class_name

このオプションパラメータを使用すると、 simplexml_import_dom() は指定したクラスのオブジェクトを返します。このクラスは SimpleXMLElement を継承していなければなりません。

戻り値

SimpleXMLElement を返します。 失敗時に null を返します。

エラー / 例外

非XMLまたは非HTMLのnodeが渡された場合、 TypeErrorをスローします。

変更履歴

バージョン 説明
8.4.0 この関数は、非XMLまたは非HTMLのnodeが渡された場合、 ValueError ではなく TypeError をスローするようになりました。

例1 DOM のインポート

<?php
$dom
= new DOMDocument;
$dom->loadXML('<books><book><title>blah</title></book></books>');
if (!
$dom) {
echo
'ドキュメントのパース時にエラーが発生しました';
exit;
}

$s = simplexml_import_dom($dom);

echo
$s->book[0]->title;
?>

上の例の出力は以下となります。

blah

参考

add a note

User Contributed Notes 3 notes

up
-1
paul dot allsopp at digital-pig dot com
2 years ago
Why not just:simplexml_import_dom(dom_import_simplexml($SimpleXmlNode))
up
-2
shirkaen at gmail dot com
8 years ago
/*If tags in DOM have text and some part of this text is surrounded by other tag, simple_import_dom object doesn't contain position of child tag, so rendering it back to html/xml can be a problem. Printing such a node is also peculiar. Eg.*///////////////////////$text = "<body><p>Some text before <em>italic </em>and after text.</p></body>";$dom = new DOMDocument;$dom->loadHTML($text);$result = simplexml_import_dom($dom);echo $result->p;////////////////////////Prints ://Some text before and after text.print_r($result->p);//Prints://SimpleXMLElement Object ( [em] => italic )print_r($result->p->em)//does more or less the same://SimpleXMLElement Object ( [0] => italic )var_dump($result->p);//Prints://object(SimpleXMLElement)#8 (1) { ["em"]=> string(7) "italic " }var_dump($result->p->em)//object(SimpleXMLElement)#9 (1) { [0]=> string(7) "italic " }//butecho $result->p->em;//prints://italic
up
-3
brandonkirsch at perceptionilluminates dot com
12 years ago
simplexml_import_dom() will accept DOMNodes or other SimpleXMLElements.  This has a useful purpose if you are extending the SimpleXMLElement class and would prefer the xpath() method to return your class extension instead of basic SimpleXMLElements.  For example:class MySimpleXML extends SimpleXMLElement{    public function xpath($xpath){         $return = array();        $simpleXmls = parent::xpath($xpath); // run SimpleXMLElement xpath, returning an array of SimpleXMLElements        foreach($simpleXmls as $xml){            $return[] = simplexml_import_dom($xml,'MySimpleXML'); // copy SimpleXMLElement, returning as MySimpleXML instance        }        return $return;    }}Now I can create an instance of MySimpleXML, run an xpath, and get my results back as an array of MySimpleXML elements instead of the native SimpleXMLElement:$mySimpleXml = new mySimpleXml('<root><node/></root>');$array = $mySimpleXml->xpath('/root/node'); // returns array with a single MySimpleXml object
To Top