1. 什么是框架
框架(framework)是一个框子 -- 指其约束性,也是一个架子 -- 指其支撑性,是一个基本概念上的结构,用于去解决或者处理复杂的问题。
框架是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法;另一种定义认为,框架是可被应用开发者定制的应用骨架。前者是从应用方面而后者是从目的方面给出的定义。
框架,其实就是某种应用的半成品,就是一组组件,供你选用完成你自己的系统。简单说就是使用别人搭好的舞台,你来做表演。
2. 为什么使用框架
1)自己从头实现太复杂
2)使用框架能够更专注于业务逻辑,加快开发速度
3)框架的使用能够处理更多细节问题
4)使用人数多,稳定性,扩展性好
3. selenium工作原理
-
原理:webdriver是按照server–client的经典设计模式设计的。
server端就是remote server,可以是任意的浏览器。当我们的脚本启动浏览器后,该浏览器就是remote server,它的职责就是等待client发送请求并做出相应;client端简单说来就是我们的测试代码,我们测试代码中的一些行为,比如打开浏览器,转跳到特定的url等操作是以http请求的方式发送给被测试浏览器,也就是remote server;remote server接受请求,并执行相应操作,并在response中返回执行状态、返回值等信息。
4. selenium环境搭建
1)python3.7
2)Firefox35(大于43)
3)selenium2框架
稳定版 2.48.0 (pip install selenium==2.48.0)
4)浏览器驱动
下载谷歌驱动
selenium之 chromedriver与chrome版本映射表
Firefox浏览器对应各个版本驱动下载地址
firefox各个版本安装包的下载地址
注意:Firefox35(大于43)版本不需要下载驱动器,大于这个版本的需要,Chrome需要下载驱动器,下边分别演示。
5. selenium对浏览器操作
1)库的导入
from selenium import webdriver
2)创建浏览器对象
driver = webdriver.xxx()
使用dir(driver)查看方法
# 必须为大写
driver = webdriver.Firefox()
driver = webdriver.Chrome()
3)浏览器尺寸相关操作
maximize_window() 最大化
get_window_size() 获取浏览器尺寸,打印查看
set_window_size() 设置浏览器尺寸,400*400
4)浏览器位置相关操作
get_window_position() 获取浏览器位置
set_window_position(x,y) 设置浏览器位置
注意:显示器以左上角为(0,0),所有的位置操作都是相对于显示器左上角展开的位移操作,单位是像素。
5)浏览器的关闭操作
close() 关闭当前标签/窗口
quit() 关闭所有标签/窗口
6)页面请求操作
driver.get(url) 请求某个url对应的响应
refresh() 刷新页面操作
back() 回退到之前的页面
forward() 前进到之后的页面
- 案例
from selenium import webdriver
import time
# driver = webdriver.Chrome()#不可以找到,必须导入对应的驱动器
driver = webdriver.Firefox()
url1 = "http://www.baidu.com"
url2 = "https://zhuanlan.zhihu.com/"
# 请求第一个接口
driver.get(url1)
time.sleep(3)
# 刷新
driver.refresh()
driver.get(url2)
# 回退
driver.back()
time.sleep(3)
# 前进
driver.forward()
time.sleep(3)
driver.close()
6. selenium获取断言信息
1. 什么是断言
断言是编程术语,表示为一些布尔表达式,程序员相信在程序中的某个特定点该表达式值为真,可以在任何时候启用和禁用断言验证,因此可以在测试时启用断言而在部署时禁用断言。
2. 获取断言信息的操作
- current_url 获取当前访问页面url
- title 获取当前浏览器标题
- page_source 获取网页源码
print(driver.current_url)
print(driver.title)
print(driver.page_source)
- get_screenshot_as_png() 保存图片
data = driver.get_screenshot_as_png()
with open("a.png", "wb") as f:
f.write(data)
- get_screenshot_as_file(file) 直接保存
driver.get_screenshot_as_file("b.png")
7. selenium八大元素定位
from selenium import webdriver
driver = webdriver.Firefox()
# url = "http://www.baidu.com"
# driver.get(url)
# 第一种 id
# ele = driver.find_element_by_id("kw")
# ele.send_keys(12306) # 输入数据
# from selenium.webdriver.common.by import By
# ele = driver.find_element(By.ID,"kw")
# ele.send_keys(12306) # 输入数据
# 第二种 标签名字
# ele = driver.find_element_by_name("wd")
# ele.send_keys(12306) # 输入数据
# 第三种 class
# ele = driver.find_element_by_class_name("s_ipt")
# ele.send_keys(12306) # 输入数据
# 第四种 Xpath
# ele = driver.find_element_by_xpath("//*[@id='kw']")
# ele.send_keys(12306) # 输入数据
# 第五种 css class
# ele = driver.find_element_by_css_selector("#kw")
# ele.send_keys(12306) # 输入数据
# 第六种 text
# ele = driver.find_element_by_link_text("地图")
# ele.click() # 输入数据
# 第七种:类似于模糊匹配
# ele = driver.find_element_by_partial_link_text("地")
# ele.click()
# 第八种:标签名定位,必须得保证只有一个这种名字的标签,使用下面这个搜索
# url = "http://cn.bing.com/"
# driver.get(url)
# ele = driver.find_element_by_tag_name("input")
# ele.send_keys(12306) # 输入数据