XPath即为XML路径语言(XML Path Language),它是一种用来确定XML文档中某部分位置的语言。
XPath基于XML的树状结构,提供在数据结构树中找寻节点的能力。起初XPath的提出的初衷是将其作为一个通用的、介于XPointer与XSL间的语法模型。但是XPath很快的被开发者采用来当作小型查询语言。
选取节点 XPath 使用路径表达式在 XML 文档中选取节点。节点是通过沿着路径或者 step 来选取的。
下面列出了最有用的路径表达式:
表达式  | 描述  | 
|---|---|
nodename  | 选取此节点的所有子节点。  | 
/  | 从根节点选取。  | 
//  | 从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置。  | 
.  | 选取当前节点。  | 
..  | 选取当前节点的父节点。  | 
@  | 选取属性。  | 
在下面的表格中,我们已列出了一些路径表达式以及表达式的结果:
路径表达式  | 结果  | 
|---|---|
bookstore  | 选取 bookstore 元素的所有子节点。  | 
/bookstore  | 选取根元素 bookstore。 注释:假如路径起始于正斜杠( / ),则此路径始终代表到某元素的绝对路径!  | 
bookstore/book  | 选取属于 bookstore 的子元素的所有 book 元素。  | 
//book  | 选取所有 book 子元素,而不管它们在文档中的位置。  | 
bookstore//book  | 选择属于 bookstore 元素的后代的所有 book 元素,而不管它们位于 bookstore 之下的什么位置。  | 
//@lang  | 选取名为 lang 的所有属性。  | 
XPath 使用路径表达式来选取 XML 文档中的节点或者节点集。这些路径表达式和我们在常规的电脑文件系统中看到的表达式非常相似。路径表达式是从一个XML节点(当前的上下文节点)到另一个节点、或一组节点的书面步骤顺序。这些步骤以“/”字符分开,每一步有三个构成成分:
一般情况下,我们使用简写后的语法。虽然完整的轴描述是一种更加贴近人类语言,利用自然语言的单词和语法来书写的描述方式,但是相比之下也更加啰嗦。
轴可定义相对于当前节点的节点集。
轴名称  | 结果  | 
|---|---|
ancestor  | 选取当前节点的所有先辈(父、祖父等)。  | 
ancestor-or-self  | 选取当前节点的所有先辈(父、祖父等)以及当前节点本身。  | 
attribute  | 选取当前节点的所有属性。  | 
child  | 选取当前节点的所有子元素。  | 
descendant  | 选取当前节点的所有后代元素(子、孙等)。  | 
descendant-or-self  | 选取当前节点的所有后代元素(子、孙等)以及当前节点本身。  | 
following  | 选取文档中当前节点的结束标签之后的所有节点。  | 
namespace  | 选取当前节点的所有命名空间节点。  | 
parent  | 选取当前节点的父节点。  | 
preceding  | 选取文档中当前节点的开始标签之前的所有节点。  | 
preceding-sibling  | 选取当前节点之前的所有同级节点。  | 
self  | 选取当前节点。  | 
每个步均根据当前节点集之中的节点来进行计算。
步(step)包括:
步的语法:
轴名称::节点测试[谓语]
实例
例子  | 结果  | 
|---|---|
child::book  | 选取所有属于当前节点的子元素的 book 节点。  | 
attribute::lang  | 选取当前节点的 lang 属性。  | 
child::*  | 选取当前节点的所有子元素。  | 
attribute::*  | 选取当前节点的所有属性。  | 
child::text()  | 选取当前节点的所有文本子节点。  | 
child::node()  | 选取当前节点的所有子节点。  | 
descendant::book  | 选取当前节点的所有 book 后代。  | 
ancestor::book  | 选择当前节点的所有 book 先辈。  | 
ancestor-or-self::book  | 选取当前节点的所有 book 先辈以及当前节点(如果此节点是 book 节点)  | 
child::*/child::price  | 选取当前节点的所有 price 孙节点。  |