当前位置: 首页 > 图文教程 > 网络编程 > PHP > 在PHP5中使用DOM控制XML(1)

PHP
PHP中上传大体积文件时需要的设置
用PHP生成PDF文件 with FPDF
在同一窗体中使用PHP来处理多个提交任务
PHP经验交流:php访问access的方法
PHP实用手册:PHP常用正则表达式收集
也用PHP来实现网页静态发布的两种方法
PHP使用zlib扩展实现页面GZIP压缩输出
PHP的语言层面的优化以及代码优化技巧
PHP实例:上传多个图片并校验的代码
用php+odbc+access数据库来操作函数
用PHP来实现页面GZIP的压缩输出教程
PHP进阶技巧:php用流方式制作缩略图
使用php 5时MySQL返回乱码的解决办法
新手如何使用PHP来创建RSS的阅读器
PHP实用:用PHP来实现图片的简单上传
利用php和js来轻松实现页面数据的刷新
在PHP中使用随机数的三个步骤详细代码
PHP进阶技巧:如何避免表单的重复提交
PHP技术进阶 PHP SOCKET 技术研究
PHP技术进阶:php用流方式制作缩略图

在PHP5中使用DOM控制XML(1)


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 114 ::
收藏到网摘: n/a

PHP5中增强了XML的支持,使用DOM扩展了XML操作的能耐。这些函数作为 PHP5 核心的一部分,无需被安装即可使用。
  
  下面的例子简单的演示了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 . "\n";
   }
   }
   }
  }
  */
  
  //使用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&代表目录深度)
  */