xpath定位(二)轴定位

第一篇讲了xpath定位的一些基本定位方法,这里再介绍一种:xpath轴定位,应用场景是当某个元素的各个属性及其组合都不足以定位时,那么可以利用其兄弟节点或者父节点等各种可以定位的元素进行定位。

1.xpath轴是什么

w3cschool上的定义如下:

语法

2.具体应用

(1)descendant表示取当前节点的所有后代元素

定位百度首页的“百度一下”按钮

可以看到, <input>标签的父元素是<span>标签,而<span>标签的父元素是<form>标签,所以可以通过先定位<form>标签,然后利用descendant定位<input>标签

xpath路径如下:

xpath= "//form[@id='form']/descendant::input[@id='su']"

//form[@id='form']表示找到id属性为'form'的<form>标签,descendant::input表示找到<form>标签的所有后代<input>标签,然后通过[@id='su']精准定位到id属性为'su'的<input>标签

把路径放到浏览器控制台,按下Ctrl+F,然后输入xpath路径,查看一下,确实定位到了<input>标签(在执行程序之前,可以通过这种方式来验证一下写的xpath路径是否正确

(2)following表示选取当前节点结束标签之后的所有节点

注意这里说的是“结束标签之后”,所以在用这个轴进行定位时要看清目标标签的与辅助定位标签的层级关系

所以上例中就不能通过<form>标签结合following来定位,因为<input>标签在<form>标签里面;

分析一下:<input>标签的上级是一个<span>标签,这个<span>标签上面也有一个<span>标签,可以通过它来定位

xpath= "//span[@id='s_kw_wrap']/following::input[@id='su']"
//span[@id='s_kw_wrap']表示定位到id属性为s_kw_wrap的<span>标签,/following::input[@id='su']表示找到<span>结束标签(即</span>)后的所有input标签,然后通过[@id='su']精准定位到id属性为'su'的<input>标签

(3)parent::可指定要查找的当前节点的直接父节点,例如,父节点是个div,即可写成parent::div,如果要找的元素不是直接父元素,则不可使用parent,可使用ancestor,代表父辈、祖父辈等节点;

child::表示直接子节点元素

following-sibling只会标识出当前节点结束标签之后的兄弟节点,而不包含其他子节点

https://www.guru99.com/这个网站为例,

定位Learn Python,思路如下:先定位Learn SQL,然后找到Learn SQL的父节点li,然后再找li的兄弟节点,即包含Learn Python的那个li标签,然后再找li的孩子节点,也就是a标签

//a[text()='Learn SQL']/parent::li/following-sibling::li/child::a[text()='Learn Python']
也可以这样写//a[text()='Learn SQL']/parent::li/following-sibling::li[3]/a

(4).//和//的区别

//是指从全文上下文中搜索//后面的节点,而.//则是指从前面的节点的子节点中进行查找

(参考博客:https://blog.csdn.net/qingchunjun/article/details/54772940

### 回答1: XPath 是一种用于在 XML 和 HTML 文档中定位元素的语言。在 Web 自动化测试中,我们可以使用 XPath 定位元素并执行相应的操作。 以下是使用 XPath 定位元素的方法: 1. 使用绝对路径:可以通过使用完整的路径来定位元素。例如,使用 Chrome 浏览器的开发者工具,可以右键单击要定位的元素,然后选择“Copy XPath”选项来获取该元素的 XPath。 2. 使用相对路径:可以使用元素的属性、标签名、文本内容等来定位元素。例如,可以使用以下代码定位一个具有特定文本内容的元素: ``` //div[contains(text(),'some text')] ``` 3. 使用索引:如果页面中有多个相同的元素,可以使用索引来定位元素。例如,以下代码将定位第一个具有特定类名的 div 元素: ``` //div[@class='some-class'][1] ``` 4. 使用:可以使用 XPath 定位与当前元素相关的元素。例如,以下代码将定位当前元素的父元素: ``` ../ ``` 以上是 XPath 定位元素的一些常用方法。在实际应用中,我们可以根据具体情况选择最适合的方法来定位元素。 ### 回答2: XPath(XML Path Language)是一种用于在XML文档中定位元素的语言。在编写Web自动化测试脚本时,XPath可以帮助我们快速准确地定位元素,实现自动化测试的目的。 使用XPath定位元素的方法有两种:绝对路径和相对路径。 绝对路径是指从根节点开始一直到目标元素的完整路径。使用绝对路径时,要用斜杠(/)作为分隔符来表示各级元素之间的关系。例如,要定位一个网页上的某个元素,可以使用绝对路径表示如/html/body/div[1]/div[2]/a。 相对路径是指相对于当前节点的路径。使用相对路径时,要用双斜杠(//)来表示各级元素之间的关系。相对路径的好处是不需要完整路径,只需要根据当前节点的层级关系来描述即可。例如,要定位一个网页上的某个元素,可以使用相对路径表示如//div[@class='content']/a。 XPath定位元素时可以结合元素的属性和属性值进行定位。使用[@属性名='属性值']的形式可以根据元素的属性值来定位元素。例如,//input[@id='txtUsername']表示通过元素的id属性来定位元素。 同时,XPath还支持通过元素的文本内容来定位元素。使用[text()='文本内容']的形式可以根据元素的文本内容来定位元素。例如,//a[text()='登录']表示通过元素的文本内容来定位元素。 XPath还可以使用逻辑运算符来定位元素,如and、or和contains等。通过结合多个条件,可以更准确地定位元素。例如,//input[@id='txtUsername' and @type='text']表示通过元素的id属性和type属性来定位元素。 综上所述,XPath定位元素是一种非常强大和灵活的方法,可以通过元素的层级关系、属性值和文本内容来精确定位元素,实现自动化测试的目的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值