快捷键:一般在windows系统上打开浏览器开发者工具都是按F12 火狐浏览器:在页面上点击右键选择‘查看元素’
谷歌浏览器:在页面上点击右键选择‘检查’
使用
方法一:在要查看的元素上点击右键选择‘查看元素’或者‘检查’
方法二:先打开浏览器开发者工具,点击选择元素的图标,移动鼠标到要查看的元素,然后点击
3. 元素定位方式
Selenium提供了八种定位元素方式
1. id
2. name
3. class_name
4. tag_name
5. link_text
6. partial_link_text
7. XPath
8. CSS
3.1 id定位
说明:id定位就是通过元素的id属性来定位元素,HTML规定id属性在整个HTML文档中必须是唯一的;前提:元素有id属性
id定位方法
element = driver.find_element_by_id(id)
案例
案例演示环境说明:
受限于网络速度的影响,我们案例采用本地的html页面来演示。这样可以提高学习效率和脚本执行速率
。
需求:打开注册A.html页面,完成以下操作
1). 使用id定位,输入用户名:admin
2). 使用id定位,输入密码:123456
3).3秒后关闭浏览器窗口
案例实现步骤分析
1. 导入selenium包 --> from selenium import webdriver
2. 导入time包 --> import time
3. 实例化浏览器驱动对象 --> driver = webdriver.Firefox()
4. 打开注册A.html --> driver.get(url)
5. 调用id定位方法 --> element = driver.find_element_by_id("")
6. 使用send_keys()方法输入内容 --> element.send_keys("admin")
7. 暂停3秒 --> time.sleep(3)
8. 关闭浏览器驱动对象 --> driver.quit()
说明:为了更好的学习体验,我们先暂时使用下send_keys()方法来输入内容
3.2 name定位
说明:name定位就是根据元素name属性来定位。HTML文档中name的属性值是可以重复的。前提:元素有name属性
name定位方法
element = driver.find_element_by_name(name)
案例
需求:打开注册A.html页面,完成以下操作
1). 使用name定位用户名,输入:admin
2). 使用name定位密码,输入:123456
3).3秒后关闭浏览器窗口
3.3 class_name定位
说明:class_name定位就是根据元素class属性值来定位元素。HTML通过使用class来定义元素的样式。前提:元素有class属性
注意:如果class有多个属性值,只能使用其中的一个
class_name定位方法
element = driver.find_element_by_class_name(class_name)
案例
需求:打开注册A.html页面,完成以下操作
1). 通过class_name定位电话号码A,并输入:18611111111
3).3秒后关闭浏览器窗口
3.4 tag_name定位
说明:tag_name定位就是通过标签名来定位;
HTML本质就是由不同的tag组成,每一种标签一般在页面中会存在多个,所以不方便进行精确定位,一般很少使用
tag_name定位方法
element = driver.find_element_by_tag_name(tag_name)
如果存在多个相同标签,则返回符合条件的第一个标签如何获取第二个元素?稍后讲解
案例
需求:打开注册A.html页面,完成以下操作
1).使用tag_name定位用户名输入框,并输入:admin
2).3秒后关闭浏览器窗口
3.5link_text定位
说明:link_text定位是专门用来定位超链接元素(<a>标签</a>),并且是通过超链接的文本内容来定位元素
。
link_text定位方法
element = driver.find_element_by_link_text(link_text)
link_text:为超链接的全部文本内容
案例需求:打开注册A.html页面,完成以下操作
1).使用link_text定位(访问 新浪 网站)超链接,并点击
2).3秒后关闭浏览器窗口
3.6 partial_link_text定位
说明:partial_link_text定位是对link_text定位的补充,link_text使用全部文本内容匹配元素,而partial_link_text可以使用局部来匹配元素,也可以使用全部文本内容匹配元素。
partial_link_text定位方法
element = driver.find_element_by_partial_link_text(partial_link_text)
partial_link_text:可以传入a标签局部文本-能表达唯一性
案例
需求:打开注册A.html页面,完成以下操作 1).使用partial_link_text定位(访问 新浪 网站)超链接,并点击 2).3秒后关闭浏览器窗口
4. 定位一组元素
在我们学习使用以上方法的时候,发现有个共同的相似方法:
4.1 find_elements_by_xxx()
作用:
1). 查找定位所有符合条件的元素
2). 返回的定位元素格式为数组(列表)格式; 说明:
1). 列表数据格式的读取需要指定下标(下标从0开始)
4.2 案例
需求:打开注册A.html页面,完成以下操作
1).使用tag_name定位密码输入框(第二个input标签),并输入:123456
2).3秒后关闭浏览器窗口
4.3示例代码
driver.find_elements_by_tag_name("input")[1].send_keys("123456")