Rumah  >  Artikel  >  pembangunan bahagian belakang  >  在PHP5中使用DOM控制XML(1)

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

黄舟
黄舟asal
2016-12-15 12:57:491156semak imbas

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 "


取得所有的title元素:
"; 
  $titles = $dom -> getElementsByTagName("title"); 
  foreach ($titles as $node) 
  { 
   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/channel/item/title"); 
  foreach ($titles as $node) 
  { 
   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&代表目录深度) 
  */

以上就是在PHP5中使用DOM控制XML(1)的内容,更多相关文章请关注PHP中文网(www.php.cn)!


Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn