• xpath简明实例教程(简化版)(转)


    <AAA>
              <BBB/>
              <CCC/>
              <BBB/>
              <BBB/>
              <DDD>
                   <BBB/>
              </DDD>
              <CCC/>
         </AAA>

    一、基本的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[normalize-space(@name)='bbb']
    选择含有属性name且其值(在用normalize-space函数去掉前后空格后)为'bbb'的BBB元素

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

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

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

    八、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元素

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

    /AAA
    等价于 /child::AAA

    /child::AAA
    等价于/AAA

    /AAA/BBB
    等价于/child::AAA/child::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::*
    /AAA/BBB节点同层次的他之后兄弟节点

    //CCC/following-sibling::*
    所有CCC节点的它之后的兄弟节点

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

    /AAA/BBB/following-sibling::*
    /AAA/BBB节点同层次的他之前兄弟节点

    //CCC/following-sibling::*
    所有CCC节点的它之前的兄弟节点

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

    /AAA/XXX/following::*
    /AAA/XXX之后的除了它的祖先节点以外的它之后所有节点

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

    /AAA/XXX/preceding::*
    /AAA/XXX之后的除了它的祖先节点以外的它之前的所有节点

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

    /AAA/XXX/descendant-or-self::*
    包含/AAA/XXX自身的及它的子孙的节点

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

    /AAA/XXX/DDD/EEE/ancestor-or-self::*
    包含/AAA/XXX/DDD/EEE自身的及它的祖先的节点,不包含兄弟节点

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

    二十二、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元素

    转自:http://www.zvon.org/xxl/XPathTutorial/Output_chi/example1.html

  • 相关阅读:
    2019牛客暑期多校训练营(第三场)B题、H题
    2019牛客暑期多校训练营(第四场)k题、j题
    Manacher算法 & Palindrome
    HDU 3336——Count the string
    判断一个点是否在三角形内
    P1052 过河
    P1353 [USACO08JAN]跑步Running
    hdu 1686 Oulipo
    Cyclic Nacklace HDU
    高精地图技术分析
  • 原文地址:https://www.cnblogs.com/myparamita/p/1442185.html
Copyright © 2020-2023  润新知