笔记:
01.设置元素等待时间
自动化测试的时候,元素定位没有错,但是跑脚本的时候却报错了
例如,登录的时候要等登录页面加载出来才能输入用户名和密码
selenium设置元素等待时间的3种方式及区别
1.sleep() --固定等待时间:强制等待,不能把握准确的等等时间,适合调试时用
2.implicitly_wait() --隐式等待时间:等页面加载完成才执行下一步操作,一般设置一次即可
3.WebDriverWait --显示等待时间:配合untill()和not untill()方法,根据判断条件 灵活处理等待时间
要先设置一个超长时间,在这个时间内,程序根据调用频率每隔几秒查看一下,如果条件满足,则执行下一步操作,若不满足且超过了等待时间则抛出异常
导包:from selenium.webdriver.support.ui import WebDriverWait
使用:WebDriverWait(driver, 超时时间, 调用频率, 要忽略的异常).until(要执行的方法, 超时时返回的错误信息)
实例:
replace:
02.键盘事件Keys类
制表符:send_keys(Keys.TAB)
退出键:send_keys(Keys.ESCAPE)
F1:send_keys(Keys.F1) f1~f12 以此类推
03.二次定位
顾名思义,通过多个元素,定位两次
dr.find_element(By.CLASS_NAME,"s_input").send_keys("python")
二次定位:
dr.find_element(By.NAME,"query").find_element(By.CLASS_NAME,"s_input").send_keys("python")
04.selenium鼠标悬停类-- ActionChains()
导包:from selenium.webdriver.common.action_chainsimport ActionChains
实例:将鼠标移动至更多设置,悬停鼠标
elem1= dr.find_element(By.LINK_TEXT,"设置")
ActionChains(dr).move_to_element(elem1).perform()
05.selenium警告框的处理
很多web应用经常会遇到JavaScript编写的alert 、confirm 以及prompt 弹窗,需要用到switch_to.alert来切换弹窗,并对弹窗进行输入信息,关闭等处理。
switch_to.alert.text --获取弹窗文本信息
switch_to.alert.accept() --点击弹窗中确定按钮
switch_to.alert.dismiss() --点击弹出中取消按钮
switch_to.alert.sendKeys("字符串") --在弹窗中输入信息
实例:
06.下拉菜单选择的三种方式
导包:from selenium.webdriver.support.uiimport Select
#选择下拉框的o2
elem1 = dr.find_element(By.ID,"s3Id")
1:根据value值定位
Select(elem1).select_by_value("o2val")
2.根据index定位
Select(elem1).select_by_index(1)
3.根据下拉框文本信息定位
Select(elem1).select_by_visible_text("o2")
07.多窗口切换
window_handles --获取所有窗口句柄
switch_to.window(指定窗口) --切换到指定窗口
08.selenium之JS操作浏览器滚动条位置
execute_script("window.scrollTo(0,n);")
09.selenium之JS操作隐藏元素
隐藏元素的标识:style="display:none;"
一般我们通过将隐藏元素的属性修改成显示再定位
10.操作excel文件
将测试数据参数化用到
10.1准备参数化数据文件
10.2导包
打开文件,填写文档路径
运行结果:
定位到sheet的位置
读取sheet的行和列的内容
#读取表的行的方法
rows = sheet1.nrows
print("行数",rows)
columns = sheet1.ncols
print("列数",columns)
读取指定行的值
#读取指定行的值
rowValue1 = sheet1.row_values(0)
print(rowValue1)
#读取指定列的值
colValue1 = sheet1.col_values(0)
print(colValue1)
#输出所有用户名和对应的密码
for iin range(1,rows):
print("用户名:" + sheet1.row_values(i)[0] +",密码:" + sheet1.row_values(i)[1])