PHP
发布时间:2019-11-18 发布网站:大佬教程 code.js-code.com
大佬教程收集整理的这篇文章主要介绍了PHP5中使用DOM控制XML实现代码,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
下面的例子简单的演示了DOM对XML的操作,详细解释请看代码中的注释
<div class="codetitle"><a style="cursOR: pointer" data="10068" class="copybut" id="copybut10068" onclick="doCopy('code10068')"> 代码如下:
<div class="codebody" id="code10068">
<?
/
**** use XML in php5
reference site:
http://cn.php.net/manual/zh/ref.dom.php
the follow codes need
php5 support
*
****/ //首先要创建一个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 "
取得所有的
title元素:
";
$
titles = $dom -> getElementsByTagName("
title"
); foreach ($
titles as $nod
E){ echo $node -> textContent . "
";
//这样也可以
//echo $node->firstChild->data . "
";
} /
echo "
从根结点遍历所有结点:
";
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 . "\n";
}
}
}
}
/ //使
用XPath查询数据
echo "
使
用XPath查询的
title节点结果:
";
$xpath = new domxpath($dom
); $
titles = $xpath->query("/rss/ch
Annel/item/
title"
); foreach ($
titles as $nod
E){ echo $node->textContent."
";
}
/
这样和使用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&代表目录深度)
/
//向DOM中写入新数据
$item = $dom->createElement("item"
); $
title = $dom->createElement("
title"
); $
titleText = $dom->createTextNode("
Title TEXT"
); $
title->appendChild($
titleText
); $item->appendChild($
titlE);
$dom->documentElement->getElementsByTagName('ch
Annel')->item(0)->appendChild($item
); //从DOM中删除节点
//$dom->documentElement->RemoveChild($dom->documentElement->getElementsByTagName("ch
Annel")->item(0)
); //或者使
用Xpath查询出节点
再删除 //$dom->documentElement->RemoveChild($xpath->query("/rss/ch
Annel")->item(0)
); //$dom->save("newfile.xml"
); //从DOM中修改节点数据
//修改第一个
title的文件
//这个地方比较笨,新创建一个节点,然后替换旧的节点。如果哪位朋友有其他好的方法请一定要告诉我
$first
title = $xpath->query("/rss/ch
Annel/item/
title")->item(0
); $new
title = $dom->createElement("
title"
); $new
title->appendChild(new DOMText("This's the new
Title TEXT!!!")
); $first
title->parentNode->
replaceChild($new
title,$first
titlE);
//修改属性
//$first
title = $xpath->query("/rss/ch
Annel/item/
title")->item(0
); //$first
title->setAttribute("orderby","4"
); $dom->save("newfile.xml"
); echo "
<a href=\"newfile.xml\">查看newfile.xml"; //下面的代码获得并解析
php.net的首页,将返第一个
title元素的内容。
/
$dom->loadHTMLFile("http://www.php.net/");
$title = $dom->getElementsByTagName("title");
print $title->item(0)->textContent;
/
?>