zoukankan      html  css  js  c++  java
  • XPath学习笔记

    背景

    最近在做UI自动化, UI自动化的元素定位绕不开XPath, 抽空学习了XPath相关知识, 这里做下学习笔记.

    XPath简介

    XPath, 全称 XML Path Language, 即XML路径语言, 是一门在XML文档中查找信息的语言.

    XPath是使用路径表达式来选去XML文档中的节点或者节点集. 节点是通过沿着路径(path)或者步(steps)来选取的.

    XPath语法

    路径表达式:

    表达式 描述
    nodename 选取此节点的所有子节点
    / 从当前节点选取直接子节点
    // 从匹配选择的当前节点选择所有子孙节点
    . 选取当前节点
    .. 选取当前节点的父节点
    @ 选取属性

    谓语(Predicates)

    谓语用来查找某个特定的节点或者包含某个指定的值的节点.
    谓语被嵌在方括号中

    谓语 描述
    n 第n个元素
    last() 最后一个元素
    last()-n 倒数第n+1个元素
    position()<n 选取前n-1个元素
    @XXX 可以嵌套表达式

    选取未知节点

    XPath通配符可以用于选取未知的XML元素.

    通配符 描述
    * 匹配任何元素节点
    @* 匹配任何属性节点
    node() 匹配任何类型的节点

    选取若干路径

    通过在路径表达式中使用“|”, 可以选取若干个路径.

    eg:

    路径表达式 结果
    //* 匹配文档中的所有元素
    //title[@*] 匹配所有带有属性的title元素
    //title //price
    /bookstore/book[price>35.00] 选取 bookstore 元素的所有 book 元素,且其中的 price 元素的值须大于 35.00。

    XPath标准函数

    XPath包含有超过100个内建函数. 这些函数用于字符串值、数值、日期和时间比较、节点和QName处理、序列处理、逻辑值等.

    函数 描述
    contains(@AA, "XXX") 属性AA是否包含XXX的元素
    starts-with(string1,string2) 如果 string1 以 string2 开始,则返回 true,否则返回 false。
    ends-with(string1,string2) 如果 string1 以 string2 结尾,则返回 true,否则返回 false。
    matches(string,pattern) 如果 string 参数匹配指定的模式,则返回 true,否则返回 false。

    其他关键信息

    1.支持的运算符

    and、or、mod、+、-、*、div、=、!=、<、<=、>、>=

    2.XPath Axes(轴)

    • 轴可定义相对于当前节点的节点集.
    • 语法: 轴::节点选择器
    锚点 描述
    ancestor::节点选择器 选取当前节点的所有先辈(父、祖父等)。
    ancestor-or-self 选取当前节点的所有先辈(父、祖父等)以及当前节点本身。
    attribute::节点选择器 选取当前节点的所有属性值
    child 选取当前节点的所有直接子元素
    descendant 获取当前节点的所有后代元素(子、孙等)
    following 获取当前节点的结束标签之后的所有节点
    following-sibling 可以获取当前节点之后的所有同级节点
    namespace 选取当前节点的所有命名空间节点。
    preceding 选取文档中当前节点的开始标签之前的所有节点。
    self 选取当前节点
  • 相关阅读:
    NHibernate+MySql (erro 解决方法)
    Android详细的对话框AlertDialog.Builder使用方法
    Android调用WebService
    android连接Mysql数据库之JDBC方式
    ASP.NET MVC 过滤器Filter
    C#动态生成html页
    MVC中提示错误:从客户端中检测到有潜在危险的 Request.Form 值的详细解决方法
    Asp.Net生命周期系列三
    Asp.Net生命周期系列二
    Asp.Net生命周期系列一
  • 原文地址:https://www.cnblogs.com/amyzhu/p/10225583.html
Copyright © 2011-2022 走看看