热门标签 | 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



推荐阅读
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社区 版权所有