忽然觉的这两天轻松许多,不像以前那样整天索事烦身。刚才看了下博客的访问统计,发现搜索DOMDocument的还蛮多的。顺手将我对Php DOMDocument的一点见解分享一下。昨天写了一篇关于Php Xml处理之simplexml使用方法浅谈,个人觉的simplexml对解析上更实际,简便一些。
这里也只说一下如何使用PHP DOMDocument解析XML文件,关于生成XML文件以后再说。
关于用到的XML文件还以“Php Xml处理之simplexml使用方法浅谈”一文中的XML为例,文件名为:me.xml。代码如下:
PHP XML处理XML代码<?xml version=”1.0″ encoding=”utf-8″?>
<phplamp>
<post>
<title ><details>详细内容一</details>
</post>
<post>
<title ><details>详细内容二</details>
</post>
<post>
<title ><details>详细内容三</details>
</post>
</phplamp>
然后就需要用PHP的DOMDocument去处理这个文件,将XML文件中的任何元素都解析出来。代码如下,里面有注释。
PHP Xml解析DOMDocument代码<?php
// 首先要建一个DOMDocument对象
$xml = new DOMDocument();
// 加载Xml文件
$xml->load(‘me.xml’);
// 获取所有的post标签
$postDom = $xml->getElementsByTagName(‘post’);
// 循环遍历post标签
foreach($postDom as $post){
// 获取Title标签Node
$title = $post->getElementsByTagName(‘title’);
/**
* 要获取Title标签的Id属性要分两部走
* 1. 获取title中所有属性的列表也就是$title->item(0)->attributes
* 2. 获取title中id的属性,因为其在第一位所以用item(0)
*
* 小提示:
* 若取属性的值可以用item(*)->nodeValue
* 若取属性的标签可以用item(*)->nodeName
* 若取属性的类型可以用item(*)->nodeType
*/
echo ‘Id: ’ . $title->item(0)->attributes->item(0)->nodeValue . ‘<br />’;
echo ‘Title: ’ . $title->item(0)->nodeValue . ‘<br />’;
echo ‘Details: ’ . $post->getElementsByTagName(‘details’)->item(0)->nodeValue . ‘<br /><br />’;
}
?>
这只是一种方法,DOMDocument相当强大,还有更多的解析方法与策略,等待您去发掘…