XPATH

XPATH

基本的XPath语法类似于在一个文件系统中定位文件,如果路径以斜线 / 开始,那么该路径就表示到一个元素的绝对路径

/AAA                    选择根元素AAA

/AAA/CCC              选择AAA的所有CCC子元素

/AAA/DDD/BBB       选择AAA的子元素DDD的所有子元素

 

如果路径以双斜线 // 开头,则表示选择文档中所有满足双斜线//之后规则的元素(无论层级关系)

//BBB               选择所有BBB元素

//DDD/BBB     选择所有父元素是DDD的BBB元素

 

星号 * 表示选择所有由星号之前的路径所定位的元素

/AAA/CCC/DDD/*           选择所有路径依附于/AAA/CCC/DDD的元素

/*/*/*/BBB                                选择所有的有3个祖先元素的BBB元素

//*                                     选择所有元素

 

方块号里的表达式可以进一步的指定元素, 其中数字表示元素在选择集里的位置, 而last()函数则表示选择集中的最后一个元素.

/AAA/BBB[1]                    选择AAA的第一个BBB子元素

/AAA/BBB[last()]              选择AAA的最后一个BBB子元素

//@id                                选择所有的id属性

//BBB[@id]                      选择有id属性的BBB元素

//BBB[@name]                选择有name属性的BBB元素

//BBB[@*]                       选择有任意属性的BBB元素

//BBB[not(@*)]                选择没有属性的BBB元素

 

属性的值可以被用来作为选择的准则, normalize-space函数删除了前部和尾部的空格, 并且把连续的空格串替换为一个单一的空格

//BBB[@id='b1']                                      选择含有属性id且其值为'b1'的BBB元素

//BBB[@name='bbb']                              选择含有属性name且其值为'bbb'的BBB元素

//BBB[normalize-space(@name)='bbb']        选择含有属性name且其值(在用normalize-space函数去掉前后空格后)为'bbb'的BBB元素

 

count()函数可以计数所选元素的个数

//*[count(BBB)=2]           选择含有2个BBB子元素的元素

//*[count(*)=2]                 选择含有2个子元素的元素

//*[count(*)=3]                 选择含有3个子元素的元素

 

name()函数返回元素的名称, start-with()函数在该函数的第一个参数字符串是以第二个参数字符开始的情况返回true, contains()函数当其第一个字符串参数包含有第二个字符串参数时返回true.

//*[name()='BBB']                    选择所有名称为BBB的元素(这里等价于//BBB)

//*[starts-with(name(),'B')]      选择所有名称以"B"起始的元素

//*[contains(name(),'C')]         选择所有名称包含"C"的元素

 

string-length函数返回字符串的字符数,你应该用&lt;替代<, 用&gt;代替>

//*[string-length(name()) = 3]  选择名字长度为3的元素

//*[string-length(name())< 3]  选择名字长度小于3的元素

//*[string-length(name())> 3]  选择名字长度大于3的元素

 

多个路径可以用分隔符 | 合并在一起

//CCC | //BBB                  选择所有的CCC和BBB元素

/AAA/EEE | //BBB            选择所有的BBB元素和所有是AAA的子元素的EEE元素

/AAA/EEE | //DDD/CCC| /AAA | //BBB           可以合并的路径数目没有限制

 

child轴(axis)包含上下文节点的子元素, 作为默认的轴,可以忽略不写.

/AAA                                等价于/child::AAA

/child::AAA                       等价于/AAA

/AAA/BBB                        等价于/child::AAA/child::BBB

/child::AAA/child::BBB     等价于/AAA/BBB

/child::AAA/BBB              二者都可以被合并

 

descendant (后代)轴包含上下文节点的后代,一个后代是指子节点或者子节点的子节点等等, 因此descendant轴不会包含属性和命名空间节点.

/descendant::*                         选择文档根元素的所有后代.即所有的元素被选择

/AAA/BBB/descendant::*        选择/AAA/BBB的所有后代元素

//CCC/descendant::*              选择在祖先元素中有CCC的所有元素

//CCC/descendant::DDD                选择所有以CCC为祖先元素的DDD元素

 

parent轴(axis)包含上下文节点的父节点, 如果有父节点的话

//DDD/parent::*                       选择DDD元素的所有父节点

 

ancestor轴(axis)包含上下节点的祖先节点, 该祖先节点由其上下文节点的父节点以及父节点的父节点等等诸如此类的节点构成,所以ancestor轴总是包含有根节点,除非上下文节点就是根节点本身.

/AAA/BBB/DDD/CCC/EEE/ancestor::*          选择一个绝对路径上的所有节点

//FFF/ancestor::*                                             选择FFF元素的祖先节点

 

following-sibling轴(axis)包含上下文节点之后的所有兄弟节点

/AAA/BBB/following-sibling::*                 

//CCC/following-sibling::*                       

 

preceding-sibling 轴(axis)包含上下文节点之前的所有兄弟节点

/AAA/XXX/preceding-sibling::*

//CCC/preceding-sibling::*             

 

following轴(axis)包含同一文档中按文档顺序位于上下文节点之后的所有节点, 除了祖先节点,属性节点和命名空间节点

/AAA/XXX/following::*             

//ZZZ/following::*                     

 

following轴(axis)包含同一文档中按文档顺序位于上下文节点之前的所有节点, 除了祖先节点,属性节点和命名空间节点

/AAA/XXX/preceding::*           

//GGG/preceding::*                

 

descendant-or-self 轴(axis)包含上下文节点本身和该节点的后代节点

/AAA/XXX/descendant-or-self::*             

//CCC/descendant-or-self::*                  

ancestor-or-self 轴(axis)包含上下文节点本身和该节点的祖先节点

/AAA/XXX/DDD/EEE/ancestor-or-self::*

//GGG/ancestor-or-self::*                       

ancestor, descendant, following, preceding 和self轴(axis)分割了XML文档(忽略属性节点和命名空间节点), 不能交迭, 而一起使用则包含所有节点

//GGG/ancestor::*          

//GGG/descendant::*     

//GGG/following::*          

//GGG/preceding::*        

//GGG/self::*                   

//GGG/ancestor::* |//GGG/descendant::* | //GGG/following::* | //GGG/preceding::* | //GGG/self::*                     

 

div运算符做浮点除法运算, mod运算符做求余运算, floor函数返回不大于参数的最大整数(趋近于正无穷), ceiling返回不小于参数的最小整数(趋近于负无穷)

//BBB[position() mod 2 = 0 ]          

选择偶数位置的BBB元素

//BBB[ position() =floor(last() div 2 + 0.5) or position() = ceiling(last() div 2 + 0.5) ]

选择中间的BBB元素

//CCC[ position() =floor(last() div 2 + 0.5) or position() = ceiling(last() div 2 + 0.5) ]

选择中间的CCC元素

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值