概述
- Selenium提供的几种定位方式
# 根据元素id进行查找 dr.find_element_by_id('id') # 根据name属性值进行查找 dr.find_element_by_name('name') # 根据类名进行查找 dr.find_element_by_class_name('classname') # 根据css选择器进行查找 dr.find_element_by_tag_name('css_expression') # 根据xpath进行查找 dr.find_element_by_xpath('xpath_expression') # 根据链接文本进行查找 dr.find_element_by_link_text('link_text') # 根据链接为本进行模糊匹配 dr.find_element_by_partial_link_text('partial_pattern')
- 定位方式一般情况下的优先级
总的原则其实是哪种方式能得到唯一精确的结果就用哪个。在都不能得到精确结果的时候,几种常用的方式的优先级顺序为:
id-name-class-css_selector-xpath-其它
为何css_selector的优先级高于xpath:
a) css是针对html的,实现的原理与css中匹配对象的机制,而xpath对应配合xml工作,它实现的原理是遍历的原理,显然css性能更优
b) 表达式相对xpath往往要简单很多
c) 前端开发主要用css,所以在元素定位困难时,也更易于和开发进行沟通 - css_selector与xpath的语法
# css_selector语法 # 1.id选择器:#id # 2.class选择器:.class # 3.标签选择器:E(标签名称) # 4.子元素选择器:E>F, E元素的所有子元素F # 5.后代元素选择器:E F. 所有E元素的后代元素F # 6.毗邻元素选择器:E+F, 紧随E元素之后的同级元素F(只匹配第一个) # 7.同级元素选择器:E~F, 所有在E元素之后的同级元素F # 8.正则表达式规则查找: E[att^='val'], att以val开头的元素E E[att$='val'],att以val结尾的元素E E[att*='val'], att包含val的元素E E[att1='v1'][att2='v2'], att1为v1,att2为v2的元素E E:contains('xxxx') 内容包含xxxx的元素E # xpath语法 # 1.全路径定位:/html/body/table/.... # 2.节点属性://input(@value='内容') # 3.节点文本://option[text()='内容'] # 4.关联属性定位://input(@type='' and @value='') # 5.父节点定位://table[@class='']/thead[@class=''] # 6.下标定位://*[@id='']/td[2] # 7.模糊匹配属性://tr[contains(@id, '***')]/td[2]
- 补充
# 除上述定位方式外,还有一个通用的API:find_element() from selenium.webdriver.common.by import By from selenium import webdriver dr = webdriver.Chrome() dr.get("http://www.baidu.com") dr.find_element(By.ID, 'id')
最后
以上就是鲤鱼小霸王为你收集整理的Selenium几种元素定位方式的全部内容,希望文章能够帮你解决Selenium几种元素定位方式所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复