这一次的分享主要关注元素定位
官方的webdriver提供了8种元素定位方法
id,name,class name,tag name,link text,partial link text,xpath,css selector
在python中对应的定位方法如下(以单个元素举例)
find_element_by_id() find_element_by_name() find_element_by_class_name() find_element_by_tag_name() find_element_by_link_text() #专门定位链接 a标签 find_element_by_partial_link_text() find_element_by_xpath() find_element_by_css_selector()
查看页面元素:firebug或chrome控制台
一般F12都会打开控制台
确定元素是否唯一
1、firepath和firebug组合:下载地址:https://addons.mozilla.org/en-US/firefox/addon/firepath/
可以设置获取css还是xpath,简单好用,左下角会给出匹配的元素节点个数
如下图:
2、浏览器控制台-console下面输入JavaScript脚本:
document.getElementByClassName('filename');效果如下图
有静态id的,首选id,也要注意是否是动态id,以126邮箱登录为例:
![]()
![]()
很清楚的看到刷新页面后,email输入框的id是变化的,这种就无法用id定位,可以选择name属性
定位一组元素然后根据索引选择需要定位的元素
当页面上有多个元素属于同一属性类型,我们也可以定位这一组元素,然后根据索引选择合适的元素
实例图如下
el = driver.find_elements_by_class_name('list-head-cell-first') #el = driver.find_elements_by_css_selector('.list-head-cell-first') ba = el[0]
定位方法的选择顺序
第一阵营:id,name,link text
第二阵营:class,css,js
第三阵营:xpath、tag name,复数定位(定位一组然后根据索引选择)