XPath节点匹配

    不是原创,只是归纳整理了一下。

  1. 路径匹配 
    符  号含  义举  例匹配结果
    /指示节点路径/A/C/D节点"A"的子节点"C"的子节点"D",即id值为d2的D节点
    /根节点
    //所有路径以"//"后指定的子路径结尾的元素//E所有E元素,结果是所有三个E元素
    //C/E所有父节点为C的E元素,结果是id值为e1和e2的两个E元素
    *路径的通配符/A/B/C/*A元素→B元素→C元素下的所有子元素,即name值为b的B元素、id值为d1的D元素和id值为e1和e2的两个E元素
    /*/*/D上面有两级节点的D元素,匹配结果是id值为d2的D元素
    //*所有的元素
    |逻辑或//B | //C所有B元素和C元素


  2. 位置匹配
    举  例含  义匹配结果
    /A/B/C[1]A元素→B元素→C元素的第一个子元素name值为b的B元素
    /A/B/C[last()]A元素→B元素→C元素的最后一个子元素id值为e2的E元素
    /A/B/C[position()>1]A元素→B元素→C元素之下的位置号大于1的元素id值为d1的D元素和两个具有id值的E元素


  3. 属性及属性
    举  例 含  义 匹配结果//B[@id] 所有具有属性id的B元素 id值为b1和b2的两个B元素//B[@*] 所有具有属性的B元素 两个具有id属性的B元素和一个具有name属性B元素//B[not(@*)] 所有不具有属性的B元素 A元素→C元素下的B元素//B[@id="b1"] id值为b1的B元素 A元素下的B元素


     
  4. 亲属关系匹配
    举  例含  义匹配结果
    //E/parent::*所有E节点的父节点元素id值为a1的A元素和id值为c1的C元素
    //F/ancestor::*所有F元素的祖先节点元素id值为a1的A元素和id值为c2的C元素
    /A/child::*A的子元素id值为b1、b2的B元素,id值为c2的C元素,以及没有任何属性的E元素
    /A/descendant::*A的所有后代元素除A元素以外的所有其它元素
    //F/self::*所有F的自身元素F元素本身
    //F/ancestor-or-self::*所有F元素及它的祖先节点元素F元素、F元素的父节点C元素和A元素
    /A/C/descendant-or-self::*所有A元素→C元素及它们的后代元素id值为c2的C元素、该元素的子元素B、D、F元素
    /A/C/following-sibling::*A元素→C元素的紧邻的后序所有兄弟节点元素没有任何属性的E元素
    /A/C/preceding-sibling::*A元素→C元素的紧邻的前面所有兄弟节点元素id值为b1和b2的两个B元素
    /A/B/C/following::*A元素→B元素→C元素的后序的所有元素id为b2的B元素、无属性的C元素、无属性的B元素、id为d2的D元素、无属性的F元素、无属性的E元素。
    /A/C/preceding::*A元素→C元素的前面的所有元素id为b2的B元素、id为e2的E元素、id为e1的E元素、id为d1的D元素、name为b的B元素、id为c1的C元素、id为b1的B元素


  5. 条件匹配
    条件匹配就是利用一些函数的运算结果的布尔值来匹配符合条件的节点。常用于条件匹配的函数有四大类:节点函数、字符串函数、数值函数、布尔函数。例如前面提到的last()、position()等等,以后在补充。

转载于:https://www.cnblogs.com/likang/archive/2007/07/22/827119.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值