webdriver原理
- WebDriver启动目标浏览器,并绑定到指定端口。该启动的浏览器实例,做为web driver的remote server
- Client端通过CommandExcuter发送HTTPRequest给remote server的侦听端口(通信协议:the webriver wire protocol)
- Remote server需要依赖原生的浏览器组件(如:IEDriverServer.exe、chromedriver.exe),来转化转化浏览器的native调用。
浏览器操作
# 引入依赖
from selenium import webdriver
## 浏览器最大化
driver.maximize_window()
## 设置浏览器宽和高
driver.set_window_size(400,800)
## 控制浏览器前进
driver.forward()
## 控制浏览器后退
driver.back()
## 获取当前页面title
title = driver.title
## 获取当前页面的URL地址
url = driver.current_url
简单对象定位
## 唯一
find_element_by_id()
## 唯一
find_element_by_name()
## 操作对象是文字超链接
find_element_by_linx_text()
## 操作对象是文字超链接
find_element_by_partial_link_text()
## 定位
find_element_by_class_name()
find_element_by_tag_name()
## xpath定位
find_element_by_xpath()
操作测试对象
## 清除内容
clear()
## 模拟鼠标点击操作
click()
## 向输入框输入
send_keys()
## 提交表单
submit()
WebElement接口常用方法
## 返回元素尺寸
size
## 获取元素文本信息
text
## 获取元素某个属性值
get_attribute(name)
## 该元素用户是否可见
is_displayde
鼠标事件
from selenium.webdriver.common.actionchains import ActionChains
"""
ActionChains类操作鼠标事件
ActionChains的执行原理
调用ActionChains方法的时候,用户行为不会立刻执行,而是将所有操作放在一个队列中,当执行perform()方法时,按照放入队列的顺序先进先出执行
"""
## 书写格式
ActionChains(driver).context_click(操作对象).perform()
"""
鼠标点击
"""
## 鼠标右击
context_click()
## 鼠标双击,应用场景:查看图片,双击选定文字
double_click()
## 鼠标点击
click()
## 按住鼠标左键不动
click_and_hold()
"""
鼠标移动
"""
## 移动到某个元素
move_to_element(目标元素)
## 移动到某个坐标
move_by_offset(xoffset,yoffset)
"""
鼠标拖拽
"""
## 将元素从起点source移动到终点target
drag_and_drop(source,target)
## 按照坐标移动
drag_and_drop_by_offset(source,xoffset,yoffset)
键盘事件
## 引入库文件
from selenium.webdriver.common.keys import Keys
"""
组合键
"""
## 全选
send_keys(Keys.CONTROL,'a')
## 复制
send_keys(Keys.CONTROL,'c')
## 粘贴
send_keys(Keys.CONTROL,'v')
## 剪切
send_keys(Keys.CONTROL,'x')
"""
非组合键
"""
## 回车键
send_keys(Keys.ENTER)
## 删除键
send_keys(Keys.BACK_SPACE)
## 空格键
send_keys(Keys.SPACE)
## 制表键
send_keys(Keys.TAB)
## 回退键
send_keys(Keys.ESCAPE)
## 刷新键
send_keys(Keys.F5)
设置等待时间
## 设置固定休眠时间。Python的time包提供sleep方法
sleep()
## webdriver提供的一个隐性等待的时间,在一个时间段内只能的等待,超时则抛出异常
implicitly_wait()
"""
webdriver提供的另一个方法,在设置时间内,默认每隔一段时间去检测页面元素是否存在,如果超出设置时间检测不到则抛出异常
driver - WebDriver的驱动程序(Ie, Firefox, Chrome或远程)
timeout -最长超时时间,默认以秒为单位
poll_frequency -休眠时间的间隔(步长)时间,默认为0.5秒
ignored_exceptions -超时后的异常信息,默认情况下抛NoSuchElementException异常。
"""
WebDriverWait(driver, timeout, poll_frequency=0.5, ignored_exceptions=None)
定位对象
"""
find_elements返回的是一个list
定位一组对象,一般应用于下列场景:批量操作对象,比如将页面上的CheckBox都选上
"""
find_elements_by_tag_name()
find_element_by_css_selector()
"""
定位frame中的对象
针对frame嵌套的情况,使用switch_to.frame(id/name/xpath)切换到被嵌套的frame中
"""
switch_to.frame(id/name/xpath)
多窗口处理
"""
新建窗口需要依赖于JavaScript完成
要想在多个窗口之间切换,首先要获得每一个窗口的唯一标识符号(句柄)
通过获得的句柄来区别分不同的窗口,从而对不同窗口上的元素进行操作
"""
## 获得当前窗口的句柄(可以理解为窗口的ID)
driver.current_window_handle
## 获得所有窗口的句柄
driver.window_handles
## 切换回句柄所属的窗口
driver.switch_to_handle("句柄")
## 关闭当前窗口
driver.close()
## 关闭所有窗口
driver.quit()
下拉菜单处理
"""
传统下拉菜单:先定位到下拉菜单,再点击选项
下拉菜单需点击才能显示选项:有两次点击动作,第一次点击下拉菜单,第二次点击选项
下拉菜单不需点击,鼠标放上去就会显示选项,则可以使用move_to_element()方法定位
针对下拉菜单标签是select的
"""
## 导入依赖
from selenium.webdriver.support.select import Select
## 使用方法
Select(driver.find_element_by_name("xxx")).select_by_index()
"""
选择列表
"""
## 根据index属性定位选项,index从0开始
select_by_index(index)
## 根据value属性定位
select_by_value(value)
## 根据选项文本值来定位
select_by_visible_text(text)
## 选择第一个选项
first_selected_option()
"""
清除列表
"""
## 根据index属性清除选定的选项,index从0开始
deselect_by_index(index)
## 根据value属性
deselect_by_value(value)
## 根据选项文本值
deselect_by_visible_text(text)
## 清除所有选项
deselect_all()
上传文件
上传过程一般是打开一个系统的window窗口,从窗口选择文件添加,一般会卡在如何操作Window窗口。其实,没那么复杂,只要定位上传按钮,通过send_keys()添加文件路径就可以了。
上传控件标签为input
上传控件标签为非input
可以借助第三方工具:Autolt
下载文件
webdriver允许设置默认下载路径,从而可以跳过下载弹窗提示
-
chrome下载
思路:实例化一个option对象
设置配置,并加载到option中
启动浏览器,点击下载链接
优势:使用谷歌浏览器下载,不需要针对各种文件类型进行配置
-
Firefox下载
对于Firefox,需要我们设置其Profile:
browser.download.dir:指定下载路径 browser.download.folderList:设置成2表示使用自定义下载路径;设置成0表示下载到桌面;设置成1表示下载到默认路径 browser.download.manager.showWhenStarting:在开始下载时是否显示下载管理器 browser.helperApps.neverAsk.saveToDisk:对所给出文件类型不再弹出框进行询问 ## Firefox需要针对每种文件类型进行设置,这里需要我们查询对应文件的MIME类型,可以参考MIME参考手册
处理Cookie
## 获得所有cookie
driver.get_cookies()
## 获得name属性的cookie
driver.get_cookie(name)
## 添加cookie(cookie格式为字典)
driver.add_cookie(cookie_dic)
## 删除特定cookie
driver.delete_cookie(name)
## 删除所有cookie
driver.delete_all_cookies()