XPath使用路径表达式在XML文档中进行导航,熟练掌握父子节点和属性就能熟练应用xpath
在 XPath 中,有七种类型的节点:元素、属性、文本、命名空间、处理指令、注释以及文档(根)节点。XML 文档是被作为节点树来对待的。树的根被称为文档节点或者根节点。
举例:
<bookstore>
<book>
<title lang="eng">Harry Potter</title>
<author>Rowling</author>
<year>2005</year>
<price>29.99</price>
</book>
</bookstore>
title,author,year,price都是子节点,它们的父节点是book, book的父节点是bookstore
下面列出了最有用的路径表达式:
实例
在下面的表格中,我们已列出了一些路径表达式以及表达式的结果:
谓语(Predicates)
谓语用来查找某个特定的节点或者包含某个指定的值的节点。
谓语被嵌在方括号中。
实例
在下面的表格中,我们列出了带有谓语的一些路径表达式,以及表达式的结果:
选取未知节点
XPath 通配符可用来选取未知的 XML 元素。
选取若干路径
通过在路径表达式中使用“|”运算符,您可以选取若干个路径。
注:以上内容来自 W3School
XPath模糊定位与组合定位
contains()模糊匹配,对于元素的id或者text不是固定的,但是有一部分是固定的。也可以多个属性元素组合定位
实例:
find_element_by_xpath(By.XPATH, '//*[contains(@text, "注册")]')
find_element_by_xpath(By.XPATH, '//*[contains(@content-desc, "搜索")]')
find_element_by_xpath(By.XPATH, '//*[contains(@resource-id, "注册")]')
find_element_by_xpath(By.XPATH, '//*[contains(@text, "注册")]')
find_element_by_xpath(By.XPATH, '//*[@text="注册" and @resource-id="register"]')
find_element_by_xpath(By.XPATH, '//*[@text="注册" and @index="1"]')