最近在做UI自动化, UI自动化的元素定位绕不开XPath, 抽空学习了XPath相关知识, 这里做下学习笔记.
XPath, 全称 XML Path Language, 即XML路径语言, 是一门在XML文档中查找信息的语言.
XPath是使用路径表达式来选去XML文档中的节点或者节点集. 节点是通过沿着路径(path)或者步(steps)来选取的.
| 表达式 | 描述 |
|---|---|
| nodename | 选取此节点的所有子节点 |
| / | 从当前节点选取直接子节点 |
| // | 从匹配选择的当前节点选择所有子孙节点 |
| . | 选取当前节点 |
| .. | 选取当前节点的父节点 |
| @ | 选取属性 |
谓语用来查找某个特定的节点或者包含某个指定的值的节点.
谓语被嵌在方括号中
| 谓语 | 描述 |
|---|---|
| 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包含有超过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。 |
and、or、mod、+、-、*、div、=、!=、<、<=、>、>=
| 锚点 | 描述 |
|---|---|
| ancestor::节点选择器 | 选取当前节点的所有先辈(父、祖父等)。 |
| ancestor-or-self | 选取当前节点的所有先辈(父、祖父等)以及当前节点本身。 |
| attribute::节点选择器 | 选取当前节点的所有属性值 |
| child | 选取当前节点的所有直接子元素 |
| descendant | 获取当前节点的所有后代元素(子、孙等) |
| following | 获取当前节点的结束标签之后的所有节点 |
| following-sibling | 可以获取当前节点之后的所有同级节点 |
| namespace | 选取当前节点的所有命名空间节点。 |
| preceding | 选取文档中当前节点的开始标签之前的所有节点。 |
| self | 选取当前节点 |
原文:https://www.cnblogs.com/amyzhu/p/10225583.html