1.导入模块总结
from selenium import webdriver
from time import sleep
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.common.action_chains import ActionChains
from selenium.webdriver.support.select import Select
from selenium.webdriver.support.ui import WebDriverWait#显示等待
import unittest
import HTMLTestRunner
2.切换总结
1.捕捉弹框并点击确定: 定义.switch_to.aleart.accept()
定义.switch_to.aleart.dismiss()
定义.switch_to.aleart.text
定义.switch_to.aleart.send_keys('要输入的内容')
2.切换框架: 定义.switch_to.default.content
定义.switch_to.frame('框架')
3.切换句柄: 定义.switch_to.window(切换的句柄)
定义.current_window.handle
定义.window.handle
3.切换的方式
1.弹窗不需要专门去切换
2.框架,需要回到默认框架再去想去的框架,并不能直接前往
3.句柄,需要获得所有句柄,获得所有句柄后用变量去承接这些句柄,一般后打开的句柄会相对的在列表的后面,
如果是两个句柄的切换可直接获得当前的句柄后用if语句去切换
4.元素定位的方式
1.定义.find_element(定位方式,“值”)例:定义.find_element(id,"wd")
2..定义.find_element('元素的id')
3..定义.find_element(link_text,'当前标签是a标签时可用')
4.定义.find_element(partition_link_text,'当前标签是a标签时可用')
5.定义.find_element(tag_name,'元素的标签')一般用于复选框
6.定义.find_element(xpath,'元素的路径')
7.定义.find_element(class_name,'元素的class的值')
8.定义.find_element(css_selector,'元素的名字')#用法和xpath一样
9.如果一个页面有多个同名的元素,则使用父级定位的方式,进行元素的定位
browser.find_element(id,‘父级相同的元素值’).find_element(link_text,"子级元素的内容").click()
5.点击方式
1.click()#纯点击
2.submit()#提交并点击
6.检查点
1.定义.find_element(id,'id的值').get_attribute('元素的某个变量')#获得id这个变量的某些值
2.定义.find_element(id,'id的值').size # 获得长宽高等数值以列表展示
3.定义.find_element(class_name,'class的值').text #获得文本信息
4.定义.current_url #获得地址
5.定义.title #获得跳转页面的抬头
6.WebDriverWait(定义,如果没找到的时间,多久找一次).until(lambda y:y.find_element_by_id("要找的元素的值"))
#用显示等待也可做检查点
7.鼠标操作
1.context_click(定位的元素名) #右击
2.double_click(定位的元素名) #双击
3.drag_and_drop(A元素名,B元素名) #将A元素拖拽到B元素上,前提是A元素本身是可以拖拽的
4.move_to_element(定位的元素名) #鼠标悬停
5.click_and_hold('定位的元素名')
6.click()
鼠标操作的使用方式和平常的有点不一样要先:
ActionChains(定义).鼠标操作.perform()
8.键盘操作
1.Keys.ESCAPE #键盘的esc
2.Keys.ENTER #回车键
3.Keys.SPACE #空格键
4.Keys.CONTROL #ctrl键
5.Keys.BACK_SPACE #回退键/删除键
6.Keys.ALT #alt键
7.Keys.CANCEL #取消键跟esc很相似
8.Keys.DELETE #删除键
9.Keys.TAB #tab键
键盘操作的方式是在定位元素后用send_keys(键盘操作)
如:bs.find_element_by_name('wd').send_keys(Keys.BACK_SPACE)
这个意思是定位‘百度一下’这个按钮,然后回车
9.显示等待
1.WebDriverWait(定义,如果没找到的时间,多久找一次) #如仅需做一个显示等待只需执行第一行代码
2. .until(lambda y:y.find_element_by_id("要找的元素的值")) #如需做检查点需要一二行连在一起
显示等待需要导入模块
10.隐式等待
1.定义.imlicitly_wait(最多等待的时间) #默认会在每一行代码执行单位是秒,不需导入模块,
#会等代码找到元素,直到等待的时间到了为止
11.异常捕捉
try:
可能会不正常的代码
except Exception:
发生错误后的代码
Exception 捕捉所有异常
raise nameError #有raise抛出异常后except后面的代码不会执行要想执行需将raise去掉
#只有try中报错eccept才会执行
finally:
不论报不报错都会执行的代码
12.架构的方法
1.先写出用例
2.将用例的公共模块做成方法
3.将原用例的的内容替换为方法
4.把原用例模块化
4.做一个执行所有用例的all_test
5.用调用用例的作为模块导入all_test
7.导入新报告的模块
8.将报告模块优化
9.将用例放入容器中
10.公共模块__init__里导入原用例作为模块
10.新建文件classname,里面导入公共模块的所有模块名
10.做一个方法
11.在classname里面做一个做一个方法,方法里面列表list里面放原用例的(用例名.类名)有多个用例用逗号隔开
12.列表=classname文件名的类名
13.用for循环去便利这个列表
13.页面滚动
1.js="var q=document.docunmetElement.scrollTop=位置" #置顶,位置一般是个像素,1000
DL.execute_script(js) #本来DL赋值中的引号会被当做字符串,但是使用执行脚本的函数,将会把引号中的内容进行执行
2.target = 定义.find_element_by_link_text('关注管理')
定义.execute_script("arguments[0].scrollIntoView();", target) #把页面拖到制定元素的位置,推荐使用
#如果想要将滚动条拉动到页面的一般,则必须找开发了解当前滚动条的像素大小
#一般情况下,拉到底部,一般写个10000就够了
14.好用的小命令
1.定义.close #关闭当前窗口
2.scroll 滚动 Top顶部
3.execute 执行
4.script 脚本
5定义.get_screenshot_as_file('图片保存的路径') 截图,快照