热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Webdriver中元素定位的多种技术与策略

在Webdriver中,元素定位是自动化测试的关键环节。本文详细介绍了8种常用的元素定位技术与策略,包括ID、名称、标签名、类名、链接文本、部分链接文本、XPath和CSS选择器。每种方法都有其独特的优势和适用场景,通过合理选择和组合使用,可以显著提高测试脚本的稳定性和效率。此外,文章还探讨了在复杂页面结构中如何灵活运用这些定位技术,以应对各种挑战。

webdriver提供了8种元素定位方法:

1、id

2、name

3、tag name

4、class name

5、link text

6、partial link text

7、xpath

8、css

以百度首页搜索输入框为例

 

加载浏览器;

from selenium import webdriver

driver = webdriver.Chrome()

1 使用ID定位搜索输入框:

driver.find_element_by_id('kw')

2 使用name定位搜索输入框:

driver.find_element_by_name('wd')

3 使用tag name搜索输入框:

driver.find_element_by_tag_name('input')

driver.find_elements_by_tag_name('input')[1]

4 使用class name 定位:

driver.find_element_by_class_name('s_ipt')

5 使用link text定位“新闻“”链接:

新闻

driver.find_element_by_link_text("新闻")

6 使用partial link text定位:

driver.find_element_by_partial_link_text("新")

7 使用css定位搜索输入框:

a  css通过id定位时,使用"#"表示元素的id

driver.find_element_by_css_selector("#kw")

b css通过class name定位时,使用".",表示class name

driver.find_element_by_css_selector(".s_ipt")

c css通过tag name定位时,直接使用元素的标签

driver.find_element_by_css_selector("input")

d css通过其它属性定位时,直接使用元素的标签

driver.find_element_by_css_selector("[autocomplete='off']") #注意单双引号的使用

driver.find_element_by_css_selector("[maxlength='255']")

e css定位,可以在参数中加入元素的标签名称

driver.find_element_by_css_selector("input#kw")

driver.find_element_by_css_selector("input.s_ipt")

driver.find_element_by_css_selector("input[autocomp='off']")

f css的层级定位

driver.find_element_by_css_selector("form#form>span:nth-child(1)>input")

g css的逻辑运算

用有一个元素来定位元素时,如果有其他元素的属性和此元素重复,可以组合多个属性来共同定位

组合多个属性定位元素定位百度搜索框

driver.find_element_by_css_selector('input[id="kw"] and [name="wd"]')

8 使用xpath定位:

a 使用元素定位

driver.find_element_by_xpath("//input[@id='kw']")

driver.find_element_by_xpath("//input[@name='wd']")

driver.find_element_by_xpath("//input[@class='s_ipt']")

b xpath层级定位

driver.find_element_by_xpath("//input[@id='form']//span[1]//input")

driver.find_element_by_xpath("//[@class='fm']//span[1]//input")

 

转:https://www.cnblogs.com/holly-j/p/8444811.html



推荐阅读
  • Python技巧:利用Cookie实现自动登录绕过验证码
    本文详细介绍了如何通过Python和Selenium库利用浏览器Cookie实现自动登录,从而绕过验证码验证。文章提供了具体的操作步骤,并附有代码示例,帮助读者理解和实践。 ... [详细]
  • 利用Selenium与ChromeDriver实现豆瓣网页全屏截图
    本文介绍了一种使用Selenium和ChromeDriver结合Python代码,轻松实现对豆瓣网站进行完整页面截图的方法。该方法不仅简单易行,而且解决了新版Selenium不再支持PhantomJS的问题。 ... [详细]
  • 深入理解Vue.js:从入门到精通
    本文详细介绍了Vue.js的基础知识、安装方法、核心概念及实战案例,帮助开发者全面掌握这一流行的前端框架。 ... [详细]
  • Redux入门指南
    本文介绍Redux的基本概念和工作原理,帮助初学者理解如何使用Redux管理应用程序的状态。Redux是一个用于JavaScript应用的状态管理库,特别适用于React项目。 ... [详细]
  • This post discusses an issue encountered while using the @name annotation in documentation generation, specifically regarding nested class processing and unexpected output. ... [详细]
  • 主调|大侠_重温C++ ... [详细]
  • 本文深入探讨了MySQL中常见的面试问题,包括事务隔离级别、存储引擎选择、索引结构及优化等关键知识点。通过详细解析,帮助读者在面对BAT等大厂面试时更加从容。 ... [详细]
  • 基于Node.js、Express、MongoDB和Socket.io的实时聊天应用开发
    本文详细介绍了使用Node.js、Express、MongoDB和Socket.io构建的实时聊天应用程序。涵盖项目结构、技术栈选择及关键依赖项的配置。 ... [详细]
  • 本文介绍了SVD(奇异值分解)和QR分解的基本原理及其在Python中的实现方法。通过具体代码示例,展示了如何使用这两种矩阵分解技术处理图像数据和计算特征值。 ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • 本文探讨了为何相同的HTTP请求在两台不同操作系统(Windows与Ubuntu)的机器上会分别返回200 OK和429 Too Many Requests的状态码。我们将分析代码、环境差异及可能的影响因素。 ... [详细]
  • 你根本不会用百度
    本文转载自第2大脑,详情可以扫描下方二维码关注该公众号摘要:教你正确使用百度。想必你的朋友圈这两天应该被《搜索引擎百度已死》这篇文章刷屏了吧࿰ ... [详细]
  • 本文详细介绍了 Python 中的条件语句和循环结构。主要内容包括:1. 分支语句(if...elif...else);2. 循环语句(for, while 及嵌套循环);3. 控制循环的语句(break, continue, else)。通过具体示例,帮助读者更好地理解和应用这些语句。 ... [详细]
  • 百度安全应急响应中心(BSRC)与补天漏洞响应平台共同举办2021年暑期挑战赛,提供丰厚奖励、联名证书及更多惊喜。活动时间从7月12日至7月31日。 ... [详细]
  • 本文探讨了如何利用HTML5和JavaScript在浏览器中进行本地文件的读取和写入操作,并介绍了获取本地文件路径的方法。HTML5提供了一系列API,使得这些操作变得更加简便和安全。 ... [详细]
author-avatar
XsiaoHan
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有