作者:大姑氵娘祖茉茉_749 | 来源:互联网 | 2014-05-04 00:43
什么是XPathXPath(可扩大路径)是给XSL转换[XSLT]和XPointer[XPointer]的共享功效供给一个共用的句法及语义的成果。XPath的重要的目是用于对XML文档元件寻址。在支撑这个重要目标的同
什么是XPath
XPath(可扩大路径) 是给 XSL 转换[XSLT]和 XPointer [XPointer]的共享功效供给一个共用的句法及语义的成果。XPath的重要的目是用于对 XML 文档元件寻址。在支撑这个重要目标的同时,它也为字符串,数字和布尔的把持供给了基础手段。XPath 应用简明的、非 XML 句法以便於在 URIs 和 XML 属性值以内应用 XPath,XPath 对 XML 文档的抽象的、逻辑的结构而非它的表面句法进行把持,XPath 的名字源于它在 URL 中用作对 XML 文档的层次的结构进行导航一个路径标记。
除了用做寻址外,XPath 也被设计成以便它有能被用于匹配的一个自然的子集(测试一个节点是否匹配一个模式);XSLT中描写了 XPath 在这方面的应用。
XPath 将一个 XML 文档建模成为一棵节点树,有不同类型的节点,包含元素节点,属性节点和正文节点。XPath 定义了一种方法来盘算每类的节点的字串值。一些节点的类型也著名字。XPath 充分支撑 XML 命名空间[XML Names]。这样,节点的名字被建模成由一个局城部分和可能为空的命名空间 URI 组成的对;这被称为扩大名。
XPath返回的类型 1:节点聚集(无序的、无重复的节点聚集)
2:布尔(真或假)
3:数字(一个浮点数字)
4:字符串(UCS 字符的次序)
地址路径
地址路径是Xpath用于定位的一条语句,基础的语法如下:
/ 选择XML文档的根结点
/* 选择根结点的所有子节点,
*匹配任意子节点
/x 选择根结点的所有x元素
//book 选择根结点的所有后代节点中的book元素
//@id 选择含有id属性的子节点
para[1] 选择高低文节点的第一个 para 孩子
//vendor[@id='id1_2']/book 选择符合“属性id=’id1_2’”的所有book元素
/bib/vendor/book[year>2002] 选择符合“元素year>’2002’”的所有book元素
text() 选择高低文节点的所有的正文节点孩子
@name 选择高低文节点的 name 属性
@* 选择高低文节点的所有的属性
*/para 选择高低文节点的所有的 para 孙子
/doc/chapter[5]/section[2] 选择doc的第五个 chapter 的第二个 section
.//para 选择高低文节点的 para 元素子孙
para[@type='warning'] 选择的高低文节点的所有的有属性 type 且值为 warning 的 para 孩子
chapter[title='Introduction'] 选择高低文节点的 chapter 孩子假如它有一个或多个 title 孩子且字串值为 Introduction
employee[@secretary and @assistant] 选择高低文节点的所有既有 secretary 属性又有 assistant 属性的 employee 孩子
chpater[title] 选择的高低文节点中有一个或一个以上 title 孩子的 chpater 孩子
1:child 是缺省轴。例如,地址路径 div/para 是 child:
iv/child::para 的缩写。
2:属性也有缩写情势: attribute:: 能被缩写成 @。例如,地址路径 para[@type='warning'] 为 child::para[attribute::type='warning'] 的缩写,也就是选择有 type 属性且属性值为 warning 的 para 孩子。
3:// 是 /descendant-or-self::node()/ 的缩写。例如,//para 是 /descendant-or-self::node()/child::para 的缩写,因此选择文档中所有的 para 元素(即使 para 元素是文档元素,也会被 //para 所选择,由于文档元素是根节点的孩子); div//para 是 div/descendant-or-self::node()/child::para 的缩写,因此将选择 div 孩子的所有 para 子孙
核心函数库节点聚集函数last()返回一个数字,该数字即是从表达式求值高低文中的高低文大小
position()函数返回一个数字,该数字等於从表达式求值高低文中的高低文地位
count(node-set)函数返回在参数node-set中节点的个数
id(object)通过元素的唯一的ID选择他们
local-name(node-set?)返回一个节点的扩大名的局域部分
namespace-uri(node-set?)返回按照文档次序参数节点聚集中的第一个节点的扩大名的命名空间 URI,除了元素节点和属性节点外函数 namespace-uri 返回的字符串将为空
name(node-set?)返回一个字符串,字符串包含一个QName,它代表按照文档次序参数节点聚集中的第一个节点的扩大名,除了元素节点和属性节点外,由 name 函数返回的字符串将与 local-name 函数返回的字符串一样
字符串函数string(object?)函数将对象转换成字符.
concat(string, string, string*) 函数返回它的参数的联结
starts-with(string, string)假如第一个字符串参数以第二个字符串参数开端,starts-with 函数返回真,否则,返回假
contains(string, string)假如第一个字符串参数包含第二个字符串参数,contains 函数返回真,否则,返回假
substring-before(string, string)函数返回第一个字符串参数在第二个参数首次呈现之前的子字符串,或者,假如第一个字符串参数不包含第二个字符串参数则返回空字符串。例如,substring-before('1999/04/01','/') 返回 1999
substring-before(string, string)函数返回第一个字符串参数在第二个参数首次呈现之前的子字符串,或者,假如第一个字符串参数不包含第二个字符串参数则返回空字符串。例如,substring-before('1999/04/01','/') 返回 1999
substring( string , number , number? )函数返回第一个字符串参数从第二个参数所指定的地位开端,以第三个参数为长度的子字符串。例如, substring('12345',2,3) 返回 '234'。假如没有第三个参数,则返回从第二个参数所指定的地位开端直到结束。例如, substring('12345',2) 返回'2345'
string-length( string? )返回字符串中字符的个数
normalize-space(string?)函数返回空缺符规范化 后的参数字符串,该规范化是清除领头及结尾的空缺字以及用一个空缺符调换持续的空缺符
translate(string, string, string)函数返回第一个参数的字符串,其中有在第二个参数中呈现的字符都被在第三个参数中相对应地位的字符所调换。例如,translate('bar','abc','ABC') 返回字符串 BAr。假如,第二个参数里的字符在第三个参数的相对应地位没有字符(由于第二个参数里的字符串比第三个参数的字符串长),那么,第一个参数里的那个字符将被移往。例如,translate('--aaa--','abc-','ABC') 返回 'AAA'。假如在第二个参数里的字符呈现超过一次,那么,第一次的呈现决定调换的字符。假如第三个参数里的字符串比第二个参数的字符串长, 那么,过剩的字符将被疏忽