1、控制浏览器窗口

 

WebDriver 提供的 set_window_size()方法可以用来设置浏览器窗口大小。

"""
* name			      →		find_element_by_name()
* tag_name            →    find_element_by_tag_name()
* class_name		  →		find_element_by_class_name()
* link_text			  →		find_element_by_link_text()
* partial_link_text   →    find_element_by_partial_link_text()
* xpath				  →	    find_element_by_xpath()
* css_selector        →		find_element_by_css_selector()
"""
from selenium import webdriver

driver = webdriver.Chrome()

# id 定位
driver.find_element_by_id("kw")
driver.find_element_by_id("su")

# name 定位
driver.find_element_by_name("wd")

# class 定位
driver.find_element_by_class_name("s_ipt")

# tag定位
driver.find_element_by_tag_name("input")

# link text定位
driver.find_element_by_link_text("新闻")
driver.find_element_by_link_text("hao123")
driver.find_element_by_link_text("地图")
driver.find_element_by_link_text("视频")
driver.find_element_by_link_text("贴吧")

# partial link定位
driver.find_element_by_partial_link_text("一个很长的")
driver.find_element_by_partial_link_text("文本链接")

# XPath 定位
# 1、绝对路径定位
driver.find_element_by_xpath("/html/body/div/div[2]/div/div/div/from/span/input")
driver.find_element_by_xpath("/html/body/div/div[2]/div/div/div/from/span[2]/input")

# 2、利用元素属性定位
driver.find_element_by_xpath("//input[@id='kw']")
driver.find_element_by_xpath("//input[@id='su']")
driver.find_element_by_xpath("//*[@name='wd']")
driver.find_element_by_xpath("//*[@class='s_ipt']")
driver.find_element_by_xpath("//input[@maxlength='100']")
driver.find_element_by_xpath("//input[@autocomplete='off']")
driver.find_element_by_xpath("//input[@type='submit']")

# 3、层级与属性结合
driver.find_element_by_xpath("//span[@class='bg s_ipt_wr']/input")
driver.find_element_by_xpath("//form[@id='form']/span/input")
driver.find_element_by_xpath("//form[@id='form']/span[2]/input")

# 4、使用逻辑运算符
driver.find_element_by_xpath("//input[@id='kw' and @class='s_ipt']")

# 5、使用contains方法
driver.find_element_by_xpath("//span[contains(@calss,'s_ipt_wr')]/input")

# 6、使用text()方法
driver.find_element_by_xpath("//a[text(),'新闻')]")

driver.find_element_by_xpath("//a[contains(text(),'一个很长的')]")


# CSS 定位
# 1.通过class属性定位
driver.find_element_by_css_selector(".s_ipt")
driver.find_element_by_css_selector(".s_btn")

# 2、通过id属性定位
driver.find_element_by_css_selector("#kw")
driver.find_element_by_css_selector("#su")

# 3、通过标签名定位
driver.find_element_by_css_selector("input")

# 4、通过标签层级关系定位
driver.find_element_by_css_selector("span > input")

# 5、通过属性定位
driver.find_element_by_css_selector("[autocomplete=off]")
driver.find_element_by_css_selector("[name='kw']")
driver.find_element_by_css_selector('[type="submit"]')

# 6、组合定位
driver.find_element_by_css_selector("form.fm > span > input.s_ipt")
driver.find_element_by_css_selector("form#form > span > input#kw")

# 7、更多定位用法
driver.find_element_by_css_selector("[class*=s_ipt_wr]")
driver.find_element_by_css_selector("[class^=bg]")
driver.find_element_by_css_selector("[class$=wrap]")
driver.find_element_by_css_selector("form > input:nth-child(2)")
"""
*  back()     后退
*  forward()  前进
*  refresh()  刷新
"""
from selenium import webdriver

driver = webdriver.Chrome()

# 访问百度首页
first_url = 'http://www.baidu.com'
print("now access %s" %(first_url))
driver.get(first_url)

# 访问新闻页面
second_url = 'http://news.baidu.com'
print("now access %s" %(second_url))
driver.get(second_url)

# 返回(后退)到百度首页
print("back to  %s " %(first_url))
driver.back()

# 前进到新闻页
print("forward to  %s" %(second_url))
driver.forward()

driver.refresh()  # 刷新当前页面

driver.quit()
"""
*  set_window_size()   设置浏览器宽、高
*  maximize_window()   设置浏览器全屏
"""
from selenium import webdriver

driver = webdriver.Chrome()
driver.get("http://m.baidu.com")

# 参数数字为像素点
print("设置浏览器宽480、高800显示")
driver.set_window_size(480, 800)

# 设置浏览器全屏
driver.maximize_window()

driver.quit()
"""
* name             →       find_element_by_name()
* tag_name            →    find_element_by_tag_name()
* class_name        →       find_element_by_class_name()
* link_text            →       find_element_by_link_text()
* partial_link_text   →    find_element_by_partial_link_text()
* xpath               →        find_element_by_xpath()
* css_selector        →       find_element_by_css_selector()
"""
"""
*  back()     后退
*  forward()  前进
*  refresh()  刷新
"""
 
 
例子:   driver.refresh()   #刷新当前页面
"""
*  set_window_size()   设置浏览器宽、高
*  maximize_window()   设置浏览器全屏
"""

2.WebDriver 中的常用方法

"""
*  clear():				清除文本。
*  send_keys(*value):	模拟按键输入。
*  click():				单击元素。
*  size     返回元素的尺寸。
*  text     获取元素的文本。
*  get_attribute(name)   获得属性值。
*  is_displayed()        设置该元素是否用户可见。
"""
from selenium import webdriver

driver = webdriver.Chrome()
driver.get("https://www.baidu.com")

driver.find_element_by_id("kw").clear()
driver.find_element_by_id("kw").send_keys("selenium")
driver.find_element_by_id("su").click()

# submit 提交表单
search_text = driver.find_element_by_id('kw')
search_text.send_keys('selenium')
search_text.submit()

# 获得输入框的尺寸
size = driver.find_element_by_id('kw').size
print(size)

# 返回百度页面底部备案信息
text = driver.find_element_by_id("cp").text
print(text)

# 返回元素的属性值,可以是 id、 name、 type 或其他任意属性
attribute = driver.find_element_by_id("kw").get_attribute('type')
print(attribute)

# 返回元素的结果是否可见,返回结果为 True 或 False
result = driver.find_element_by_id("kw").is_displayed()
print(result)

driver.quit()

""" * clear(): 清除文本。 * send_keys(*value): 模拟按键输入。 * click(): 单击元素。 * submit():提交表单 * size 返回元素的尺寸。 * text 获取元素的文本。 * get_attribute(name) 获得属性值。 * is_displayed() 设置该元素是否用户可见。 """

(4)submit():提交表单。

例如,有些搜索框不提供搜索按钮,而是通过按键盘上的回车键完成搜索内容的提交,

这时可以通过 submit()模拟。

3、鼠标操作

"""
* perform() 执行所有 ActionChains 中存储的行为;
* context_click() 右击;
* double_click() 双击;
* drag_and_drop() 拖动;
* move_to_element() 鼠标悬停。
"""
from selenium import webdriver
# 引入 ActionChains 类
from selenium.webdriver.common.action_chains import ActionChains


driver = webdriver.Chrome()
driver.get("https://www.baidu.com")

# 定位到要鼠标悬停的元素
above = driver.find_element_by_link_text("设置")
# 对定位到的元素执行鼠标悬停操作
ActionChains(driver).move_to_element(above).perform()

# ……
# 引入 ActionChains 类
from selenium.webdriver.common.action_chains import ActionChains
 
 
"""
* perform() 执行所有 ActionChains 中存储的行为;
* context_click() 右击;
* double_click() 双击;
* drag_and_drop() 拖动;
* move_to_element() 鼠标悬停。
"""

4、键盘操作

"""
* 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)
* send_keys(Keys.F1) 键盘 F1
  ……
* send_keys(Keys.F12) 键盘 F12
"""
from selenium import webdriver
# 引入Keys模块
from selenium.webdriver.common.keys import Keys

driver = webdriver.Chrome()
driver.get("http://www.baidu.com")

# 输入框输入内容
driver.find_element_by_id("kw").send_keys("seleniumm")

# 删除多输入的一个m
driver.find_element_by_id("kw").send_keys(Keys.BACK_SPACE)

# 输入空格键+“教程”
driver.find_element_by_id("kw").send_keys(Keys.SPACE)
driver.find_element_by_id("kw").send_keys("教程")

# ctrl+a 全选输入框内容
driver.find_element_by_id("kw").send_keys(Keys.CONTROL, 'a')

# ctrl+x 剪切输入框内容
driver.find_element_by_id("kw").send_keys(Keys.CONTROL, 'x')

# ctrl+v 粘贴内容到输入框
driver.find_element_by_id("kw").send_keys(Keys.CONTROL, 'v')

# 通过回车键来代替单击操作
driver.find_element_by_id("su").send_keys(Keys.ENTER)

driver.quit()
# 引入Keys模块
from selenium.webdriver.common.keys import Keys
 
 
"""
* 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)
* send_keys(Keys.F1) 键盘 F1
  ……
* send_keys(Keys.F12) 键盘 F12
"""

5、获得验证信息

在进行 Web 自动化测试中,用得最多的几种验证信息是 title、current_url 和 text。

— title:用于获取当前页面的标题。

— current_url:用于获取当前页面的 URL。

— text:用于获取当前页面的文本信息。

"""
*  title         获取当前页面title
*  current_url   获取当前页面URL
*  text          获得文本信息
"""
from selenium import webdriver
from time import sleep

driver = webdriver.Chrome()
driver.get("https://www.baidu.com")
print('Before search================')

# 打印当前页面title
title = driver.title
print("title:"+ title)

# 打印当前页面URL
now_url = driver.current_url
print("URL:"+now_url)

driver.find_element_by_id("kw").send_keys("selenium")
driver.find_element_by_id("su").click()
sleep(2)

print('After search================')

# 再次打印当前页面title
title = driver.title
print("title:"+title)

# 打印当前页面URL
now_url = driver.current_url
print("URL:"+now_url)

# 获取搜索结果条数
num = driver.find_element_by_class_name('nums').text
print("result:"+num)

driver.quit()

""" * title 获取当前页面title * current_url 获取当前页面URL * text 获得文本信息 """

6、设置元素等待

显式等待

显式等待是  WebDriver  等待某个条件成立则继续执行,否则在达到最大时长时抛出超

时异常(TimeoutException)。

WebDriverWait(driver,  timeout,  poll_frequency=0.5,  ignored_exceptions=None)

	driver:浏览器驱动。
	timeout:最长超时时间,默认以秒为单位。
	poll_frequency:检测的间隔(步长)时间,默认为 0.5s。
	ignored_exceptions:超时后的异常信息,默认情况下抛出 NoSuchElementException
异常。
WebDriverWait()一般与  until()或  until_not()方法配合使用,下面是  until()和  until_not()
方法的说明。

until(method,  message=″)
调用该方法提供的驱动程序作为一个参数,直到返回值为 True。

until_not(method,  message=″)
调用该方法提供的驱动程序作为一个参数,直到返回值为 False。

JAVA selenium设置页面展示百分比 selenium设置浏览器窗口大小_Chrome

"""
*  presence_of_element_located()  方法判断元素是否存在
"""
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC

driver = webdriver.Chrome()
driver.get("http://www.baidu.com")

element = WebDriverWait(driver, 5, 0.5).until(
    EC.visibility_of_element_located((By.ID, "kw"))
    )
element.send_keys('selenium')
driver.quit()
这里需要学习一下预期判断条件搭配显性等待一起用
WebDriverWait(driver,  timeout,  poll_frequency=0.5,  ignored_exceptions=None)
    driver:浏览器驱动。
     timeout:最长超时时间,默认以秒为单位。
     poll_frequency:检测的间隔(步长)时间,默认为 0.5s。
     ignored_exceptions:超时后的异常信息,默认情况下抛出 NoSuchElementException
 异常。 
 
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
 
 
WebDriverWait(driver, 5, 0.5)#设置最长时间为5秒,检测间隔为0.5s
 
 
element = WebDriverWait(driver, 5, 0.5).until(
    EC.visibility_of_element_located((By.ID, "kw"))
    )

普通等待(自定义元素等待)

"""
自定义元素等待
"""
from selenium import webdriver
from time import sleep, ctime

driver = webdriver.Chrome()
driver.get("http://www.baidu.com")

print(ctime())
for i in range(10):
    try:
        el = driver.find_element_by_id("kw22")
        if el.is_displayed():
            break
    except:
        pass
    sleep(1)
else:
    print("time out")
print(ctime())

driver.quit()

from time import sleep

sleep(1)

隐式等待

"""
*  implicitly_wait() 隐式等待
"""
from selenium import webdriver
from selenium.common.exceptions import NoSuchElementException
from time import ctime

driver = webdriver.Firefox()

# 设置隐式等待为10秒
driver.implicitly_wait(10)
driver.get("http://www.baidu.com")

try:
    print(ctime())
    driver.find_element_by_id("kw22").send_keys('selenium')
except NoSuchElementException as e:
    print(e)
finally:
    print(ctime())
    driver.quit()

""" * implicitly_wait() 隐式等待 """

implicitly_wait()的参数是时间,单位为秒,本例中设置的等待时间为  10s。首先,这 10s 并非一个固定的等待时间,它并不影响脚本的执行速度。其次,它会等待页面上的所有 元素。当脚本执行到某个元素定位时,如果元素存在,则继续执行;如果定位不到元素, 则它将以轮询的方式不断地判断元素是否存在。假设在第 6s 定位到了元素,则继续执行, 若直到超出设置时间(10s)还没有定位到元素,则抛出异常。

定位一组元素

WebDriver 还提供了 8 种用于定位一组元素的方法。

find_elements_by_id()
find_elements_by_name()
find_elements_by_class_name()
find_elements_by_tag_name()
find_elements_by_link_text()
find_elements_by_partial_link_text()
find_elements_by_xpath()
find_elements_by_css_selector()

定位一组元素的方法与定位单个元素的方法非常像,唯一的区别是单词“element”后
面多了一个“s”,用来表示复数。
"""
*  find_elements_xxx("xx")   定位一组元素
"""
from selenium import webdriver
from time import sleep

driver = webdriver.Chrome()
driver.get("https://www.baidu.cn")

driver.find_element_by_id("kw").send_keys("selenium")
driver.find_element_by_id("su").click()
sleep(2)

# 定位一组元素
texts = driver.find_elements_by_xpath("//div[@tpl='se_com_default']/h3/a")

# 计算匹配结果个数
print(len(texts))

# 循环遍历出每一条搜索结果的标题
for t in texts:
    print(t.text)

driver.quit()

""" * find_elements_xxx("xx") 定位一组元素 """

相比定位一个元素多了一个 s

8、多表单切换

在  Web  应用中经常会遇到  frame/iframe  表单嵌套页面的应用,WebDriver  只能在一个
页面上对元素进行识别和定位,无法直接定位  frame/iframe  表单内嵌页面上的元素,这时
就需要通过 switch_to.frame()方法将当前定位的主体切换为 frame/iframe 表单的内嵌页面。

在  Web  应用中经常会遇到  frame/iframe  表单嵌套页面的应用,WebDriver  只能在一个
页面上对元素进行识别和定位,无法直接定位  frame/iframe  表单内嵌页面上的元素,这时
就需要通过 switch_to.frame()方法将当前定位的主体切换为 frame/iframe 表单的内嵌页面。
"""
*  switch_to.frame()  进入表单
*  switch_to.default_content()  退出表单至根页面
"""
from selenium import webdriver
from time import sleep

driver = webdriver.Chrome()
driver.get("http://www.126.com")
sleep(2)

login_frame = driver.find_element_by_css_selector('iframe[id^="x-URS-iframe"]')
driver.switch_to.frame(login_frame)
driver.find_element_by_name("email").send_keys("username")
driver.find_element_by_name("password").send_keys("password")
driver.find_element_by_id("dologin").click()
driver.switch_to.default_content()

driver.quit()

""" * switch_to.frame() 进入表单 * switch_to.default_content() 退出表单至根页面 """

9、 多窗口切换

在页面操作过程中,有时单击某个链接会弹出新的窗口,这时就需要切换到新打开的 窗口中进行操作。WebDriver 提供的 switch_to.window()方法可以实现在不同的窗口间切换。

	current_window_handle:获得当前窗口句柄。
	window_handles:返回所有窗口的句柄到当前会话。
	switch_to.window():切换到相应的窗口。
"""
*  switch_to.window()  切换窗口
*  current_window_handle 获得当前窗口的句柄
*  window_handles:返回所有窗口的句柄到当前会话
"""
from selenium import webdriver
import time

driver = webdriver.Chrome()
driver.implicitly_wait(10)
driver.get("http://www.baidu.com")

# 获得百度搜索窗口句柄
search_windows = driver.current_window_handle

driver.find_element_by_link_text('登录').click()
driver.find_element_by_link_text("立即注册").click()

# 获得当前所有打开的窗口的句柄
all_handles = driver.window_handles

# 进入注册窗口
for handle in all_handles:
    if handle != search_windows:
        driver.switch_to.window(handle)
        print(driver.title)
        driver.find_element_by_name("userName").send_keys('username')
        driver.find_element_by_name('phone').send_keys('138xxxxxxx')
        time.sleep(2)
        # ……
        # 关闭当前窗口
        driver.close()


# 回到搜索窗口
driver.switch_to.window(search_windows)
print(driver.title)

driver.quit()

""" * switch_to.window() 切换窗口 * current_window_handle 获得当前窗口的句柄 * window_handles:返回所有窗口的句柄到当前会话 """

10、警告框处理

在 WebDriver 中处理 JavaScript 生成的 alert、confirm 和 prompt 十分简单,具体做法是,
首先使用  switch_to.alert()方法定位,然后使用  text、accept、dismiss、send_keys  等进行操
作。

	text:返回  alert、confirm、prompt  中的文字信息。
	accept():接受现有警告框。
	dismiss():解散现有警告框。
	send_keys():在警告框中输入文本(如果可以输入的话)。
可以使用 switch_to.alert()方法为百度搜索设置弹窗,如图 4-5 所示

JAVA selenium设置页面展示百分比 selenium设置浏览器窗口大小_当前页_02

"""
* text:返回 alert/confirm/prompt 中的文字信息。
* accept():接受现有警告框。
* dismiss():解散现有警告框。
* send_keys(keysToSend): 发送文本至警告框。
"""
from selenium import webdriver
from time import sleep

driver = webdriver.Chrome()
driver.get('https://www.baidu.com')

# 打开搜索设置
link = driver.find_element_by_link_text('设置').click()
driver.find_element_by_link_text("搜索设置").click()
sleep(2)

# 保存设置
driver.find_element_by_class_name("prefpanelgo").click()

# 获得警告框
alert = driver.switch_to.alert

# 获得警告框提示信息
alert_text = alert.text
print(alert_text)

# 接受警告框
alert.accept()

driver.quit()

""" * text:返回 alert/confirm/prompt 中的文字信息。 * accept():接受现有警告框。 * dismiss():解散现有警告框。 * send_keys(keysToSend): 发送文本至警告框。 """

11、下拉框处理

下拉框是 Web 页面常见功能之一,WebDriver 提供了 Select 类来处理下拉框。
	Select 类:用于定位<select>标签。
	select_by_value():通过 value 值定位下拉选项。
	select_by_visible_text():通过 text 值定位下拉选项。
	select_by_index():根据下拉选项的索引进行选择。第一个选项为  0,第二个选项
为 1。
"""
* Select  操作select标签的下拉框。
* select_by_value()  选择value属性选择。
* select_by_visible_text() 通过选项名称选择。
* select_by_index() 通过索引选择
"""
from selenium import webdriver
from selenium.webdriver.support.select import Select
from time import sleep

driver = webdriver.Chrome()
driver.get('https://www.w3school.com.cn/tiy/t.asp?f=eg_html_select')
driver.set_page_load_timeout(2)
driver.set_script_timeout(2)

# 切换表单
driver.switch_to.frame("iframeResult")

# 定位select标签
sel = driver.find_element_by_tag_name("select")

# value="saab"
Select(sel).select_by_value('saab')
sleep(2)

# <option>Opel</option>
Select(sel).select_by_visible_text("Opel")
sleep(2)

# 根据选项的索引选择
Select(sel).select_by_index(3)
sleep(2)

driver.quit()

""" * Select 操作select标签的下拉框。 * select_by_value() 选择value属性选择。 * select_by_visible_text() 通过选项名称选择。 * select_by_index() 通过索引选择 """

12、上传文件

上传文件是比较常见的 Web 功能之一,但 WebDriver 并没有提供专门用于上传的方法,
实现文件上传的关键在于思路。

在 Web 页面中,文件上传操作一般需要单击“上传”按钮后打开本地 Windows 窗口,
从窗口中选择本地文件进行上传。因为 WebDriver 无法操作 Windows 控件,所以对于初学
者来说,一般思路会卡在如何识别 Windows 控件这个问题上。
在 Web 页面中一般通过以下两种方式实现文件上传。
	普通上传:将本地文件路径作为一个值放在 input 标签中,通过 form 表单将这个
值提交给服务器。
	插件上传:一般是指基于 Flash、JavaScript 或 Ajax 等技术实现的上传功能。
对于通过  input  标签实现的上传功能,可以将其看作一个输入框,即通过  send_keys()
指定本地文件路径的方式实现文件上传。
"""
* send_keys() 指定文件上传路径。
"""
from selenium import webdriver
import os

file_path = os.path.abspath('./files/')

driver = webdriver.Chrome()
upload_page = 'file:///' + file_path + 'upfile.html'
driver.get(upload_page)

# 定位上传按钮,添加本地文件
driver.find_element_by_id("file").send_keys(file_path + 'test.txt')
# ……

""" * send_keys() 指定文件上传路径。 """

13、下载文件

以 Chrome 浏览器为例,演示文件的下载

"""
chrome浏览器实现下载
"""
import os
from selenium import webdriver

options = webdriver.ChromeOptions() 
prefs = {'profile.default_content_settings.popups': 0,
         'download.default_directory': os.getcwd()}
options.add_experimental_option('prefs', prefs) 

driver = webdriver.Chrome(chrome_options=options) 
driver.get("https://pypi.org/project/selenium/#files")
driver.find_element_by_partial_link_text("selenium-3.141.0.tar.gz").click()

profile.default_content_settings.popups 设置为 0,表示禁止弹出下载窗口。 download.default_directory 设置文件下载路径,使用 os.getcwd()方法获取当前脚本的目录作为下载文件的保存位置。


以 Firefox 浏览器为例,演示文件的下载

"""
firefox浏览器实现下载
"""
import os
from selenium import webdriver

fp = webdriver.FirefoxProfile()

fp.set_preference("browser.download.folderList", 2)
fp.set_preference("browser.download.dir", os.getcwd())
fp.set_preference("browser.helperApps.neverAsk.saveToDisk", "binary/octet-stream")

driver = webdriver.Firefox(firefox_profile=fp)
driver.get("https://pypi.org/project/selenium/#files")
driver.find_element_by_partial_link_text("selenium-3.141.0.tar.gz").click()

为了能在 Firefox 浏览器中实现文件的下载,我们需要通过 FirefoxProfile()对其做一些 设置。 browser.download.folderList 设置为 0,表示文件会下载到浏览器默认的下载路径;设置为 2,表示文件会下载到指 定目录。 browser.download.dir 用于指定下载文件的目录。通过  os.getcwd()方法获取当前文件的所在位置,即下载文 件保存的目录。 browser.helperApps.neverAsk.saveToDisk


14、操作 Cookie

有时我们需要验证浏览器中的  Cookie  是否正确,因为基于真实的  Cookie  是无法通过
白盒测试和集成测试的。WebDriver 提供了操作 Cookie 的相关方法,可以读取、添加和删
除 Cookie。
WebDriver 操作 Cookie 的方法如下。
	get_cookies():获得所有 Cookie。
	get_cookie(name):返回字典中 key 为“name”的 Cookie。
	add_cookie(cookie_dict):添加 Cookie。
	delete_cookie(name,optionsString):删除名为 OpenString 的 Cookie。
	delete_all_cookies():删除所有 Cookie。
"""
* get_cookies() 获得所有 cookie 信息。
* get_cookie(name) 返回字典的 key 为“ name”的 cookie 信息。
* add_cookie(cookie_dict) 添加 cookie。“ cookie_dict”指字典对象,必须有name和value 值。
* delete_cookie(name,optionsString)  删除 cookie 信息。“name”是要删除的 cookie 的名称,
                                   “optionsString”是该 cookie 的选项,目前支持的选项包括“路径”,“域”。
* delete_all_cookies() 删除所有 cookie 信息。
"""
from selenium import webdriver

driver = webdriver.Chrome()
driver.get("http://www.baidu.com")

# 获得所有cookie信息并打印
cookie = driver.get_cookies()
print(cookie)

# 添加cookie信息
driver.add_cookie({'name': 'key-aaaaaaa', 'value': 'value-bbbbbb'})

# 遍历指定的cookies
for cookie in driver.get_cookies():
    print("%s -> %s" % (cookie['name'], cookie['value']))

driver.quit()
"""
* get_cookies() 获得所有 cookie 信息。
* get_cookie(name) 返回字典的 key 为“ name”的 cookie 信息。
* add_cookie(cookie_dict) 添加 cookie。“ cookie_dict”指字典对象,必须有name和value 值。
* delete_cookie(name,optionsString)  删除 cookie 信息。“name”是要删除的 cookie 的名称,
                                   “optionsString”是该 cookie 的选项,目前支持的选项包括“路径”,“域”。
* delete_all_cookies() 删除所有 cookie 信息。
"""
 
 
delete_cookie()  和 delete_all_cookies()  方法的使用也很简单,前者通过 name 删除一个
指定的 Cookie,后者直接删除浏览器中的所有 Cookies。

15.调用JavaScript

有些页面操作不能依靠 WebDriver 提供的 API 来实现,如浏览器滚动条的拖动。这时

就需要借助 JavaScript 脚本。WebDriver 提供了 execute_script()方法来执行 JavaScript 代码。

"""
* execute_script() 调用JavaScript实现滚动条操作。
"""
from selenium import webdriver
from time import sleep

driver = webdriver.Chrome()
driver.get("http://www.baidu.com")

driver.set_window_size(800, 600)

driver.find_element_by_id("kw").send_keys("selenium")
driver.find_element_by_id("su").click()
sleep(2)

# 通过javascript设置浏览器窗口的滚动条位置
js = "window.scrollTo(100,450);"
driver.execute_script(js)
sleep(3)

driver.quit()

""" * execute_script() 调用JavaScript实现滚动条操作。 """

16、处理HTML5视频文件

"""
测试HTML5页面 -- 无效
JavaScript 有个内置的对象叫作 arguments。arguments 包含了函数调用的参数数组,[0]
表示取对象的第 1 个值。
currentSrc 返回当前音频/视频的  URL。如果未设置音频/视频,则返回空字符串。
load()、play()和 pause()  控制视频的加载、播放和暂停。
"""
from time import sleep
from selenium import webdriver

driver = webdriver.Chrome()
driver.get("http://videojs.com/")

video = driver.find_element_by_id("vjs_video_3_html5_api")

# 返回播放文件地址
url = driver.execute_script("return arguments[0].currentSrc;", video)
print(url)

# 播放视频
print("start")
driver.execute_script("arguments[0].play()", video)

# 播放15秒钟
sleep(15)

# 暂停视频
print("stop")
driver.execute_script("arguments[0].pause()", video)

driver.quit()

""" 测试HTML5页面 -- 无效 JavaScript 有个内置的对象叫作 arguments。arguments 包含了函数调用的参数数组,[0] 表示取对象的第 1 个值。 currentSrc 返回当前音频/视频的  URL。如果未设置音频/视频,则返回空字符串。 load()、play()和 pause()  控制视频的加载、播放和暂停。 """

17、滑动解锁

"""
滑动选择日历
在这个脚本中,用到下面几个方法。
	click_and_hold(): 单击并按下鼠标左键,在鼠标事件中介绍过。
	move_by_offset():移动鼠标,第一个参数为 x 坐标距离,第二个参数为 y 坐标距离。
	reset_action():重置 action。

这里使用 TouchActions 类中的 scroll_from_element()方法滑动元素,参数如下。
	on_element:滑动的元素。
	xoffset:x 坐标距离。
	yoffset:y 坐标距离。
"""
from time import sleep
from selenium import webdriver


driver = webdriver.Chrome()

driver.get("http://www.jq22.com/yanshi4976")
driver.set_page_load_timeout(2)
driver.set_script_timeout(2)

sleep(2)
driver.switch_to.frame("iframe")
driver.find_element_by_id("appDate").click()

# 定位要滑动的年、月、日
dwwos = driver.find_elements_by_class_name("dwwo")
year = dwwos[0]
month = dwwos[1]
day = dwwos[2]

# 拨动年
action = webdriver.ActionChains(driver)
action.click_and_hold(year).move_by_offset(0, 100).perform()
action.reset_actions()

# 拨动月
action2 = webdriver.ActionChains(driver)
action2.click_and_hold(month).move_by_offset(0, 150).perform()
action2.reset_actions()

# 拨动天
action3 = webdriver.ActionChains(driver)
action3.click_and_hold(day).move_by_offset(0, 150).perform()
action3.reset_actions()


# 废弃,在新的浏览器和驱动中报错
# action = webdriver.TouchActions(driver)
# action.scroll_from_element(year, 0, 5).perform()
# action.scroll_from_element(month, 0, 30).perform()
# action.scroll_from_element(day, 0, 30).perform()
# ...
"""
滑动解锁 - 失效
"""
from time import sleep
from selenium import webdriver
from selenium.webdriver import ActionChains
from selenium.common.exceptions import UnexpectedAlertPresentException

driver = webdriver.Chrome()
driver.get("https://www.helloweba.com/demo/2017/unlock/")

# 定位滑动块
slider = driver.find_elements_by_class_name("slide-to-unlock-handle")[0]
action = ActionChains(driver)
action.click_and_hold(slider).perform()

for index in range(200):
    try:
        action.move_by_offset(2, 0).perform()
    except UnexpectedAlertPresentException:
        break
    action.reset_actions()
    sleep(0.1)  # 等待停顿时间


# 打印警告框提示
success_text = driver.switch_to.alert.text
print(success_text) 
 
"""
滑动选择日历
在这个脚本中,用到下面几个方法。
  click_and_hold(): 单击并按下鼠标左键,在鼠标事件中介绍过。
  move_by_offset():移动鼠标,第一个参数为 x 坐标距离,第二个参数为 y 坐标距离。
  reset_action():重置 action。

这里使用 TouchActions 类中的 scroll_from_element()方法滑动元素,参数如下。
  on_element:滑动的元素。
  xoffset:x 坐标距离。
  yoffset:y 坐标距离。
"""

18、窗口截屏

"""
* save_screenshot() 截取窗口图片。

"""
from selenium import webdriver

driver = webdriver.Chrome()
driver.get('http://www.baidu.com')

# 对当前窗口截图,并指定图片的保存位置
driver.save_screenshot("./files/baidu_img.png")

""" * save_screenshot() 截取窗口图片。

19、关闭窗口

在前面的例子中一直使用 quit()方法,其含义为退出相关的驱动程序和关闭所有窗口。
除此之外,WebDriver 还提供了 close()方法,用来关闭当前窗口。例如,在 4.10 节中会打
开多个窗口,当准备关闭其中某个窗口时,可以用 close()方法。
quit()#关驱动
close()#关当窗口