文章目录
- 1.浏览器操作
- 2.鼠标事件
- 3.键盘事件
- 4.获取页面信息
- 5.设置等待时间
- 6.表单/窗口/警告窗操作
- 7.文件上传
- 8.验证码处理
- 9.JS处理滚动条
- 10.元素定位
1.浏览器操作
driver.maximize_window() #将浏览器最大化显示
driver.set_window_size(480, 800) #设置浏览器宽480、高800窗口显示
driver.back() #浏览器后退
driver.forward() #浏览器前进
driver.refresh() #刷新当前页面
driver.get_screenshot_as_file("路径") #截图到路径中
driver.quit() #退出浏览器
2.鼠标事件
ActionChains 类鼠标操作的常用方法:
- context_click() #右击
- double_click() #双击
- drag_and_drop() #拖动
- move_to_element() #鼠标悬停在一个元素上
- click_and_hold() #按下鼠标左键在一个元素上
通用引入类:
#在使用鼠标方法前,先引入 ActionChains 类
from selenium.webdriver.common.action_chains import ActionChains
①右击:
#定位到要右击的元素
right =driver.find_element_by_xpath("xx")
#对定位到的元素执行鼠标右键操作
ActionChains(driver).context_click(right).perform()
②双击:
#定位到要双击的元素
double =driver.find_element_by_xpath("xxx")
#对定位到的元素执行鼠标双击操作
ActionChains(driver).double_click(double).perform()
③拖动:
#定位元素的原位置
element = driver.find_element_by_name("xxx")
#定位元素要移动到的目标位置
target = driver.find_element_by_name("xxx")
#执行元素的移动操作
ActionChains(driver).drag_and_drop(element, target).perform()
④鼠标悬停:
#定位到鼠标移动到上面的元素
above = driver.find_element_by_xpath("xxx")
#对定位到的元素执行鼠标移动到上面的操作
ActionChains(driver).move_to_element(above).perform()
⑤按住左键:
#定位到鼠标按下左键的元素
left=driver.find_element_by_xpath("xxx")
#对定位到的元素执行鼠标左键按下的操作
ActionChains(driver).click_and_hold(left).perform()
3.键盘事件
- send_keys(Keys.BACK_SPACE) 删除键(BackSpace)
- send_keys(Keys.SPACE) 空格键(Space)
- send_keys(Keys.TAB) 制表键(Tab)
- send_keys(Keys.ESCAPE) 回退键(Esc)
- send_keys(Keys.ENTER) 回车键(Enter)
- send_keys(Keys.CONTROL,‘a’) 全选(Ctrl+A)
- send_keys(Keys.CONTROL,‘c’) 复制(Ctrl+C)
- send_keys(Keys.CONTROL,‘x’) 剪切(Ctrl+X)
- send_keys(Keys.CONTROL,‘v’) 粘贴(Ctrl+V)
通用引入类:
#在使用键盘按键方法前需要先导入 keys 类包
from selenium.webdriver.common.keys import Keys
举例:
driver.find_element_by_id('kw').send_keys(Keys.BACKSPACE)
driver.find_element_by_id('kw').send_keys(Keys.CONTROL,'a')
driver.find_element_by_id('kw').send_keys(Keys.CONTROL,'x')
driver.find_element_by_id('kw').send_keys(Keys.CONTROL,'v')
4.获取页面信息
from selenium import webdriver
driver = webdriver.Chrome()
driver.title #获取标题
driver.current_url #获取URL
driver.capabilities[‘version’] #获取浏览器版本号
driver.find_element_by_id('kw').size #获取元素尺寸
driver.find_element_by_id('kw').text#获取元素文本
get_attribute('id'): #获取元素属性值:id的属性值
5.设置等待时间
①强制等待:
time.sleep(3)
②隐式等待:等待全部页面元素加载完成,超时则抛异常
#添加智能等待10秒
driver.implicitly_wait(10)
③显式等待:等待某个元素加载完成,超时则抛异常
WebDriverWait(driver, timeout, poll_frequency=0.5, ignored_exceptions=None),参数解释如下:
- driver - WebDriver 的驱动程序(Ie, Firefox, Chrome 或远程)
- timeout - 最长超时时间,默认以秒为单位
- poll_frequency - 休眠时间的间隔(步长)时间,默认为 0.5 秒
- ignored_exceptions - 超时后的异常信息,默认情况下抛 NoSuchElementException 异常。
from selenium.webdriver.support.wait import WebDriverWait
WebDriverWait(driver,10).until(method,message="")
WebDriverWait(driver,10).until_not(method,message="")
6.表单/窗口/警告窗操作
①表单切换:
#先通过xpath定位到iframe
xf = driver.find_element_by_xpath('/*[@class="if"]')
#再将定位对象传给switch_to.frame()方法
driver.switch_to.frame(xf)
②窗口切换:
- current_window_handle:获得当前窗口句柄
- window_handles:返回所有窗口的句柄到当前对话
- switch_to.window(窗口句柄):切换到对应的窗口
③警告窗切换:
使用switch_to_alert()方法定位到alert/confirm/prompt
- text 返回 alert/confirm/prompt 中的文字信息。
- accept 点击确认按钮。
- dismiss 点击取消按钮,如果有的话。
- send_keys 输入值,这个 alert\confirm 没有对话框就不能用了,不然会报错。
7.文件上传
①input标签:
#通过查找到input标签,然后send进去
driver.find_element_by_id("ImgSrc").send_keys(u"%s"%tds["ImgSrc"])
②非input标签:
pip install SendKeys安装第三方库
8.验证码处理
①联系开发人员禁用验证码
②验证码识别:引入第三方库
- pip install pytesseract
- pip install PILLOW
教程:验证码识别
③cookie绕过:
- get_cookies():获取所有cookies
- driver.get_cookie(name):获取指定name的cookie:
- delete_cookie():清除指定cookie
- delete_all_cookies():清除所有cookies
- add_cookie(cookie_dict): 添加cookie的值
9.JS处理滚动条
①控制滚动条高度
- 滚动条回到顶部:
js=“var q=document.getElementById(‘id’).scrollTop=0”
driver.execute_script(js)
- 滚动条拉到底部:
js=“var q=document.documentElement.scrollTop=10000”
driver.execute_script(js)
这里可以修改scrollTop 的值,来定位右侧滚动条的位置,0是最上面,10000是最底部。
②横向滚动条:
通过左边控制横向和纵向滚动条
scrollTo(x, y)js = “window.scrollTo(100,400);”
driver.execute_script(js)
第一个参数x是横向距离,第二个参数y是纵向距离
10.元素定位
Web自动化:元素定位详解