Xpath要点

本文介绍了XPath的基本概念及其在XML文档中的应用方法。详细解释了XPath中各种节点类型,并提供了路径表达式的实用实例,包括如何使用谓语、通配符以及模糊匹配。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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"]')

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值