PHP - SimpleXMLElement::xpath() 函数



定义和用法

XML 是一种用于在网络上共享数据的标记语言,XML 既可供人类阅读,也可供机器读取。SimpleXMLElement 类在 PHP 中表示 XML 文档。

SimpleXMLElement::xpath() 函数接受一个字符串值作为参数,该参数表示一个 XPath 表达式,搜索并检索给定路径下 XML 节点的子节点。

语法

SimpleXMLElement::xpath($path);

参数

序号 参数及说明
1

path (必填)

这是一个表示 XPath 表达式的字符串值。

返回值

如果成功,此函数返回一个 SimpleXMLElement 对象数组,表示节点;如果失败,则返回 FALSE。

PHP 版本

此函数首次在 PHP 5 版本中引入,并在所有后续版本中均有效。

示例

以下示例演示了 SimpleXMLElement::xpath() 函数的用法。

<html>
   <head>
      <body>
         <?php
            $xmlstr = "<?xml version='1.0' standalone='yes'?>
            <Tutorial>
               <Name>JavaFX</Name>
               <Pages>535</Pages>
               <Author>Krishna</Author>
               <Version>11</Version>
            </Tutorial>";
            $xml = new SimpleXMLElement($xmlstr);
            $node = $xml->xpath('/Tutorial/Author');
            print_r($node);	  
         ?>      
      </body>
   </head>   
</html> 

这将产生以下结果:

Array ( [0] => SimpleXMLElement Object ( [0] => Krishna ) )

示例

以下是此函数的另一个示例,我们尝试加载 XML 文件的内容并检索指定路径的内容:

data.xml

<?xml version="1.0" encoding="utf-8"?>
<Tutorials>
   <Tutorial>
      <Name>JavaFX</Name>
      <Pages>535</Pages>
      <Author>Krishna</Author>
      <Version>11</Version>
   </Tutorial>

   <Tutorial>
      <Name>CoffeeScript</Name>
      <Pages>235</Pages>
      <Author>Kasyap</Author>
      <Version>2.5.1</Version>
   </Tutorial>
   
   <Tutorial>
      <Name>OpenCV</Name>
      <Pages>150</Pages>
      <Author>Maruti</Author>
      <Version>3.0</Version>
   </Tutorial>
</Tutorials>

Sample.htm

<html>
   <head>      
      <body>         
         <?php
            $doc = new DOMDocument;
            $xml = simplexml_load_file("data.xml");
            //file to SimpleXMLElement 
            $xml = simplexml_import_dom($xml);
		
            $node = $xml->xpath('/Tutorials/Tutorial/Name');
            print_r($node);
         ?>
      </body>
   </head>
</html>

这将产生以下输出:

Array ( 
   [0] => SimpleXMLElement Object ( [0] => JavaFX ) 
   [1] => SimpleXMLElement Object ( [0] => CoffeeScript ) 
   [2] => SimpleXMLElement Object ( [0] => OpenCV ) 
)
php_function_reference.htm
广告