python selenium xpath定位方式

本文详细介绍了XPath在XML文档中的使用方法,包括绝对定位、相对路径、标签属性定位等。强调XPath定位元素时,索引从1开始,而非0。通过各种属性和路径组合,实现对网页元素的精确查找。同时,提到了针对动态属性的定位策略,如starts-with、ends-with和contains等。还探讨了如何利用祖先、后代、同级等关系进行复杂定位,举例说明了在实际场景中如何找到并操作特定元素。
摘要由CSDN通过智能技术生成

xpath是一种在xm文档中定位的语言,详细简介,请自行参照百度百科,本文主要总结一下xpath的使用方法,个人看法,如有不足和错误,敬请指出。

注意:xpath的定位 同一级别的多个标签 索引从1开始 而不是0

1.绝对定位:

此方法最为简单,具体格式为

xxx.find_element_by_xpath(“绝对路径”)

具体例子:

xxx.find_element_by_xpath("/html/body/div[x]/form/input") x 代表第x个 div标签,注意,索引从1开始而不是0

此方法缺点显而易见,当页面元素位置发生改变时,都需要修改,因此,并不推荐使用。

2.相对路径:

相对路径,以‘//’开头,具体格式为

xxx.find_element_by_xpath("//标签")

具体例子:

xxx.find_element_by_xpath("//input[x]") 定位第x个input标签,[x]可以省略,默认为第一个

相对路径的长度和开始位置并不受限制,也可以采取以下方法

xxx.find_element_by_xpath("//div[x]/form[x]/input[x]"), [x]依然是可以省略的
在这里插入图片描述
("//*[@id=‘J_login_form’]/dl/dt/input[@id=‘J_password’]"

3.标签属性定位:

3.1标签属性定位,相对比较简单,也要求属性能够定位到唯一一个元素,如果存在多个相同条件的标签,默认只是第一个,具体格式

xxx.find_element_by_xpath("//标签[@属性==‘属性值’]")

属性判断条件:最常见为id,name,class等等,目前属性的类别没有特殊限制,只要能够唯一标识一个元素都是可以的

具体例子

xxx.find_element_by_xpath("//a[@href=’/industryMall/hall/industryIndex.ht’]")
xxx.find_element_by_xpath("//input[@value=‘确定’]")
xxx.find_element_by_xpath("//div[@class = ‘submit’]/input")

当某个属性不足以唯一区别某一个元素时,也可以采取多个条件组合的方式,具体例子

xxx…find_element_by_xpath("//input[@type=‘name’ and @name=‘kw1’]")

3.2 当标签属性很少,不足以唯一区别元素时,但是标签中间中间存在唯一的文本值,也可以定位,其具体格式

xxx.find_element_by_xpath("//标签[contains(text(),‘文本值’)]")

具体例子:

xxx.find_element_by_xpath("//iunpt[contains(text(),‘型号:’)]")

注意:尽量在html中复制此段文本,避免因为肉眼无法分辨的字符导致定位失败

3.3 其他的属性值如果太长,也可以采取模糊方法定位,直接上示例
在这里插入图片描述
xxx.find_element_by_xpath(“//a[contains(@href, ‘logout’)]”)

3.4 XPath 关于网页中的动态属性的定位,例如,ASP.NET应用程序中动态生成id属性值,可以有以下四种方法:

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属性值

当然,如果上面的单一方法不能完成定位,也可以采取组合式定位 类似("//input[@id=‘kw1’]//input[start-with(@id,‘nice’]/div[1]/form[3])

以上是普通的情况,存在可以定位的属性,当某个元素的各个属性及其组合都不足以定位时,我们可以利用其兄弟节点或者父节点等各种可以定位的元素进行定位,先看看xpath中支持的方法:

1、child 选取当前节点的所有子元素
2、parent 选取当前节点的父节点
3、descendant选取当前节点的所有后代元素(子、孙等)
4、ancestor 选取当前节点的所有先辈(父、祖父等)
5、descendant-or-self选取当前节点的所有后代元素(子、孙等)以及当前节点本身
6、ancestor-or-self 选取当前节点的所有先辈(父、祖父等)以及当前节点本身
7、preceding-sibling选取当前节点之前的所有同级节点
8、following-sibling选取当前节点之后的所有同级节点
9、preceding 选取文档中当前节点的开始标签之前的所有节点
10、following 选取文档中当前节点的结束标签之后的所有节点
11、self 选取当前节点
12、attribute 选取当前节点的所有属性
13、namespace选取当前节点的所有命名空间节点
在这里插入图片描述
上图实例,需要点击订单号为17051915200001的发货按钮,这时候不能直接定位到发货按钮,而是先要定位到订单号元素,再定位他的兄弟节点。参照上图,我们首先定位到td标签中包含订单号的td元素,然后选择其之后的同级节点,following-sibling,我们要找的元素在后面的第8个td标签下,因此定位可以写名为下面的格式

Xxx.find_element_by_xpath("//td[contains(text(),’17051915200001’)]/following-sibling::td[8]/a[@class=‘link’]")

preceding-sibling
情况类似,但是所有元素的排列顺序是相反的(和following-sibling相反),如图:
在这里插入图片描述

其他方法的使用方式相同, 11-13目前没有使用过,也没有搜索到实际使用的案例,如果有人知道,希望不吝赐教。
————————————————
版权声明:本文为CSDN博主「辉色秋天」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/huiseqiutian/article/details/73739707

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python Selenium 是一个自动化测试工具,可以使用 XPath 定位元素。XPath 是一种用于在 XML 文档中定位元素的语言,也可以用于 HTML 文档中。在 Python Selenium 中,可以使用 find_element_by_xpath() 方法来定位元素。例如: ``` from selenium import webdriver driver = webdriver.Chrome() driver.get("https://www.baidu.com") # 通过 XPath 定位搜索框 search_box = driver.find_element_by_xpath("//input[@id='kw']") # 在搜索框中输入关键字 search_box.send_keys("Python Selenium") # 提交搜索 search_box.submit() # 关闭浏览器 driver.quit() ``` 在上面的例子中,我们使用了 XPath 定位了百度搜索框,并在搜索框中输入了关键字,然后提交了搜索。XPath 的语法比较复杂,需要学习一些基本的语法规则才能灵活运用。 ### 回答2: Python Selenium 是自动化测试领域中非常流行的工具,其定位元素的方式有多种,其中 Xpath 是其中最为强大和灵活的一种。下面我们将详细讲解 Python SeleniumXpath 定位的相关知识。 1. 什么是 XpathXpath 是一种XML路径语言,它是用来选择 XML 文档中的元素和属性的语言。在 Python Selenium 中,Xpath 可以定位 web 页面中的元素。 2. Xpath 的基本语法 在 Python Selenium 中,使用 Xpath 定位元素,需要先获取到 Xpath 的路径,Xpath 语法如下: - 选择器: - "/"表示选择根节点。 - "//"表示选择任意节点。 - "."表示选择当前节点。 - ".."表示选择当前节点的父节点。 - "@"表示选择属性节点。 - 谓语: - "[]"表示添加谓语条件。 - "and"表示连接两个或多个谓语。 - "or"表示选择两个或多个元素其中一个。 - 轴: - "ancestor"表示选择当前节点的所有祖先节点。 - "ancestor-or-self"表示选择当前节点的所有祖先节点及自身。 - "attribute"表示选择当前节点的所有属性节点。 - "child"表示选择当前节点的所有子节点。 - "descendant"表示选择当前节点的所有后代节点。 - "descendant-or-self"表示选择当前节点的所有后代节点及自身。 - "following"表示选择当前节点之后的所有节点。 - "following-sibling"表示选择当前节点之后的所有同级节点。 - "parent"表示选择当前节点的父节点。 - "preceding"表示选择当前节点之前的所有节点。 - "preceding-sibling"表示选择当前节点之前的所有同级节点。 - "self"表示选择当前节点自身。 3. 实际应用 Xpath 定位元素的实际运用,需要先查看页面源代码,如下面的代码片段: ```html <div class="container"> <h1>这是一段文本</h1> <ul> <li class="item"><a href="https://www.baidu.com">百度一下</a></li> <li class="item"><a href="https://www.google.com">Google</a></li> <li class="item"><a href="https://www.bing.com">必应搜索</a></li> </ul> </div> ``` 我们可以使用以下 Xpath 定位节点: - 选择根节点:"/" - 选择 ul 节点:"/div/ul" - 选择第一个 li 节点:"/div/ul/li[1]" - 选择 class 为 item 的所有 li 节点:"/div/ul/li[@class='item']" - 选择 href 属性值等于 "https://www.baidu.com" 的 a 节点:"/div/ul/li/a[@href='https://www.baidu.com']" 如下就是使用 Python SeleniumXpath 定位元素的实例代码: ```python from selenium import webdriver # 创建 driver 对象 driver = webdriver.Chrome() # 打开目标网页 driver.get("https://www.baidu.com") # 使用 Xpath 定位搜索框,输入搜索内容 search_box = driver.find_element_by_xpath('//input[@name="wd"]') search_box.send_keys("Python Selenium Xpath") # 使用 Xpath 定位搜索按钮,点击搜索 search_button = driver.find_element_by_xpath('//input[@type="submit"]') search_button.click() # 关闭 driver 对象 driver.quit() ``` 以上实例中,我们使用 Xpath 定位搜索框和搜索按钮,并将搜索内容输入后按下搜索按钮,最后关闭 driver 对象。 总结: 本文介绍了 Python SeleniumXpath 定位的相关知识,包括 Xpath 的基本语法、Xpath 定位的应用和实例代码。学习 Xpath 定位元素,可以快速便捷地定位 web 页面中的元素,达到自动化测试的目的。 ### 回答3: Python selenium是一个在Python语言中使用的自动化测试工具库,提供了丰富的API让开发人员可以通过Python代码来模拟用户与浏览器之间的交互,从而达到自动化测试的目的。在Python selenium中,使用Xpath定位元素是非常常用的技巧之一,下面就简单介绍一下Python selenium Xpath定位的相关知识: 一、Xpath概述 Xpath(XML Path Language)即为XML路径语言,它是一种在XML文档中定位节点的语言。在HTML中,XML Path Language同样适用,可以通过Xpath定位HTML中的元素。Xpath最初是由W3C组织设计开发的,用于解析和浏览XML文档,后来经过多次升级和改进,已经成为了XML定位技术的标准之一,也广泛应用于网页自动化测试领域。 二、Xpath定位语法 在Python selenium中使用Xpath语法来定位元素时,通常有两种选择:绝对路径和相对路径。根据具体的定位需求,选择不同的路径方式会有不同的注意点和代码实现。下面针对这两种方式来具体说明: 1、绝对路径 绝对路径从 HTML 文档根目录开始,一直定位到需要操作的元素。其路径表达式的格式如下: /html/head/body/div[1]/span[2] 其中 / 表示从文档的根节点开始,html 表示文档的根元素,head 表示文档的 head 元素,body 表示文档的 body 元素,div[1] 表示 body 元素下的第一个 div 元素,span[2] 表示 div[1] 元素下的第二个 span 元素。 2、相对路径 相对路径是从已经找到的元素出发,在其子元素中查找需要操作的元素。其路径表达式的格式如下: //div[@id='content']/table/tbody/tr[2]/td[1]/a 其中 // 表示无论在文档的什么地方开始查找,div[@id='content'] 表示在id为 content 的 div 元素下面查找,table/tbody/tr[2]/td[1]/a 表示在这个 div 元素下,找到第2个 tr 元素,然后再找到这个 tr 元素下的第1个 td 元素,最后再找到这个 td 元素下的第1个 a 元素。 三、Xpath定位实战 下面就通过一个具体的实例来进一步说明Python selenium如何使用Xpath语法来定位元素: 假设我们需要登录网站http://www.baidu.com,并在搜索框中输入“Python”,在搜索结果页面查找其中一条结果,并取出其中的标题和链接。这个操作可以通过Xpath定位实现,代码如下: ```python from selenium import webdriver import time # 实例化浏览器对象 driver = webdriver.Firefox() # 打开网站首页 driver.get("http://www.baidu.com") # 查找搜索框,并在其中输入Python driver.find_element_by_xpath('//input[@id="kw"]').send_keys("Python") # 查找搜索按钮,并模拟点击 driver.find_element_by_xpath('//input[@id="su"]').click() time.sleep(2) # 根据标签名和类名来定位搜索结果中的元素 results = driver.find_elements_by_xpath('//h3[@class="t"]/a') # 遍历所有搜索结果,并输出每一个结果的标题和链接 for result in results: print(result.text) print(result.get_attribute('href')) # 关闭浏览器 driver.quit() ``` 在这段代码中,首先实例化了一个Firefox浏览器对象,并打开了http://www.baidu.com这个网站。然后使用Xpath查找了搜索输入框和搜索按钮,并模拟了一下用户的输入和点击操作。之后,使用Xpath查找了搜索结果中的所有元素,并依次遍历这些元素,分别输出它们的标题和链接。最后,调用浏览器的quit()方法关闭了浏览器。 综上,Python selenium Xpath定位是一种常用的自动化测试技巧,掌握它可以大大提高测试效率和质量。在实际应用中,需要根据具体的需求选择合适的定位路径和语法,谨慎使用并且多加实践。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值