在PHP5中使用DOM控制XML(1)
30 ڣ2008-11-22 11:44:23 ߣԴ
|
下面的例子简单的演示了DOM对XML的操作,详细解释请看代码中的注释 <? /************************************************ ** use XML in PHP5 ** reference site: ** http://cn.php.net/manual/zh/ref.dom.php ** the follow codes need PHP5 support ** www.knowsky.com *************************************************/ //首先要创建一个DOMDocument对象 $dom = new DomDocument(); //然后载入XML文件 $dom -> load("test.xml"); //输出XML文件 //header("Content-type: text/xml;charset=gb2312"); //echo $dom -> saveXML(); //保存XML文件,返回值为int(文件大小,以字节为单位) //$dom -> save("newfile.xml"); echo "<hr/>取得所有的title元素:<hr/>"; $titles = $dom -> getElementsByTagName("title"); foreach ($titles as $node) { echo $node -> textContent . "<br/>"; //这样也可以 //echo $node->firstChild->data . "<br/>"; } /* echo "<hr/>从根结点遍历所有结点:<br/>"; foreach ($dom->documentElement->childNodes as $items) { //如果节点是一个元素(nodeType == 1)并且名字是item就继续循环 if ($items->nodeType == 1 && $items->nodeName == "item") { foreach ($items->childNodes as $titles) { //如果节点是一个元素,并且名字是title就打印它. if ($titles->nodeType == 1 && $titles->nodeName == "title") { print $titles->textContent . " "; } } } } */ //使用XPath查询数据 echo "<hr/>使用XPath查询的title节点结果:<hr/>"; $xpath = new domxpath($dom); $titles = $xpath->query("/rss/channel/item/title"); foreach ($titles as $node) { echo $node->textContent."<br/>"; } /* 这样和使用getElementsByTagName()方法差不多,但是Xpath要强大的多 深入一点可能是这样: /rss/channel/item[position() = 1]/title 返回第一个item元素的所有 /rss/channel/item/title[@id = "23"] 返回所有含有id属性并且值为23的title /rss/channel/&folder&/title 返回所有articles元素下面的title(译者注:&folder&代表目录深度) */ Դ. |
