xpath元素定位常用的5种方法(相对路径)

52 篇文章 2 订阅
8 篇文章 0 订阅

一、xpath定位

定位

说明

//ul/*

ul的所有子元素

//input[2]

第2个input元素

//input[last()

最后一个input元素

input[position()< 3]

前2个input元素

//input[@value]

有value属性的input元素

//input[@name=‘password’ and @pwd=‘123456’]

属性name的值等于password并且属性pwd的值等于123456的input元素

//ul/*[5]

ul的第五个子元素

//*[text()=‘Heading’

任意包含Heading文本的元素

//input[@*=‘SYS123456’]

任意属性的值为SYS123456

1、使用标签名+节点属性定位
语法://标签名[@属性名=属性值]
find_element_by_xpath("//input[@id='input']")        #@后跟属性,可以是任何属性

在这里插入图片描述

2、组合元素索引(下标)定位
find_element_by_xpath("//*[@id='J_login_form']/*/*/input[2]”)

在这里插入图片描述

3、通过部分属性值匹配
语法://标签名[contains(@属性名,部分属性值)]、//标签名[starts-with(@属性名,部分属性值)]、//标签名[ends-with(@属性名,部分属性值)]
a.starts-with      例子: //input[starts-with(@id,'ctrl')]      解析:匹配以 ctrl开始的属性值
b.ends-with        例子://input[ends-with(@id,'_userName')]    解析:匹配以 userName 结尾的属性值
c.contains()       例子://input[contains(@id,'userName')]      解析:匹配含有 userName 属性值

在这里插入图片描述

4、使用文本内容匹配
函数:text()
语法:文本全部匹配://标签名[text()=文本内容]   

文本部分匹配-包含://标签名[contains(text(),部分文本内容)]

driver.find_element_by_xpath("//a[text()="退出"]")` #文本全部匹配
driver.find_element_by_xpath("//a[contains(text(),"出")])` #文本部分匹配

在这里插入图片描述

5、使用轴定位表达式
* ancestor:祖先节点,包括父节点
* parent:父节点
* child:子节点
* descendant:所有后代(儿子、孙子、曾孙子...)
* preceding:当前元素节点标签之前的所有节点(HTML页面之前的)
* preceding-sibling:当前元素节点标签之前的所有兄弟节点(同级)
* following:当前元素节点标签之后的所有节点
* following-sibling:当前元素节点标签之后的所有兄弟节点(同级)
* 使用语法:轴名称::节点名称前后的定位与之前一致,用/隔开即可
* //div//table/td/preceding::td/following-sibling::a//[contains(text(),"课程”)] #表示//div//table/td/路径前所有节点中找到节点名称为td的节点,向下同级下的一个兄弟节点包含文本课程

在这里插入图片描述

二、xpath定位验证

1、验证Xpath定位元素是否正确,可以在Google Chrome的elements或console中进行验证

  • 在需要定位的页面,按F12后,切换至elements列下,按下Ctrl+f键,输入xpath表达式
    在这里插入图片描述
  • 在需要定位的页面,按F12后,切换至console列下,输入表达式。语法是:$x(“your_xpath_selector”)
    在这里插入图片描述

2、表达式正确,元素定位正确时,会查找出该元素,如下图:
在这里插入图片描述
3、未定位准确,找不到该元素,查找结果为空,如图:
在这里插入图片描述
4、表达式不正确,无法正常识别情况,可能会有很多种错误,列举一个例子,如图:
在这里插入图片描述
原因:**语法中括号里需要通过双引号括起来,如果xpath语句中有双引号,要改成单引号,不然只能解析到第一对双引号的内容。**这也是需要特别注意的一点。

  • 11
    点赞
  • 98
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答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、付费专栏及课程。

余额充值