selenium 特殊场景处理

文章目录


前言

selenium处理web操作师,有很多特殊的情况需要处理,例如弹窗、内嵌网页,页签切换,js执行等,下面介绍一些可能会遇到的特殊场景


一、windows的弹窗

python 复制代码
import win32com.client

'''
创建了一个 WScript.Shell COM (Component Object Model) 对象的实例。WScript.Shell 
提供了一系列的方法和属性,可以让你执行各种与 Windows Shell 相关的操作,
比如运行应用程序、读取系统环境变量、创建快捷方式等。
'''
sh = win32com.client.Dispatch("wScript.shell")

# 因为windows的弹窗脱离了web ,只能使用系统的阻塞
time.sleep(5)

# 在windows的输入框内输入内容,通过\r\n 模拟回车(在路径外边)
# 用空格 区分多个文件
sh.send_keys('"D:/api/a.png"\r\n')

--------------------------------------------------------------✂------------------------------------------------------------------------------------

二、内嵌网页 frame

python 复制代码
# 内嵌frame 处理
# 先定位到frame这个元素
ele = driver.find_element(By.CSS_SELECTOR, "#frame_id")

# 切入内嵌网页
driver.switch_to.frame(ele)

# 获取frame里的元素
driver.find_element(By.CSS_SELECTOR, "#element_id").send_keys("123")

# 跳出frame
driver.switch_to.default_content()

--------------------------------------------------------------✂------------------------------------------------------------------------------------

三、页签切换

python 复制代码
# 获取所以的网页页签
win_sli = driver.window_handles

# 遍历,切换到目标页签就停止
for win in win_sli:
    driver.switch_to.window(win)
    if driver.title == "测试项目xxx":
        break

--------------------------------------------------------------✂------------------------------------------------------------------------------------

四、截图

python 复制代码
# 截网页全屏,官方建议为 png
driver.get_screenshot_as_file("./a.png")

# 获取元素,截取元素范围的图片,如果元素没出来就截屏,那么就等待
element = driver.find_element(By.XPATH, "//span[@class='login-btn']")
element.screenshot("./p.png")

--------------------------------------------------------------✂------------------------------------------------------------------------------------

五、弹窗

python 复制代码
'''
弹窗处理
'''
# 获取对话框对象
al = driver.switch_to.alert
# 选中确认
al.accept()
# 取消
al.dismiss()
# 输入内容 可能会不显示数据,可以自己通过控制台确认
al.send_keys("123")

--------------------------------------------------------------✂------------------------------------------------------------------------------------

六、JS执行

python 复制代码
'''
一般先使用selenium 如果说有其他的情况js更加方便,则使用js
同样的定位方式,selenium和js一样快
除了ById其他的返回的都是函数
可以和selenium一样进行元素操作,只是函数不一样
document.querySelector("这里填css表达式")
document.getElementById("根据id寻找元素")
document.getElementsByClassName("根据class属性寻找元素,返回的是列表-但不是python的列表,需要自己处理后返回)
document.getElementsByClassName()[1]

document.getElementsByName("根据name属性寻找元素")
document.getElementsByTagName("")
document.querySelector("这里填css表达式").click()
document.getElementsByName("keywords")[o].value='123'   --赋值

document.getElementById("id").removeAttribute("herf") --移除元素


const element = document.getElementById('myButton'); --获取元素


element.setAttribute('title', '这是一个按钮提示'); --设置标准属性


element.setAttribute('data-id', '12345'); ----设置自定义属性 (data-*)
element.setAttribute('data-category', 'electronics');

element.setAttribute('disabled', '');  --设置布尔属性 (如 disabled, checked)



'''

--------------------------------------------------------------✂------------------------------------------------------------------------------------

总结

记录一下一些特殊情况的处理,后续会继续补充。

相关推荐
X1A0RAN1 天前
解决selenium提示chrome版本过低问题
chrome·selenium
程序员小远1 天前
使用Jmeter进行http接口测试
自动化测试·软件测试·python·测试工具·jmeter·http·接口测试
黄名富2 天前
软件测试入门-测试用例
测试工具·测试用例
程序员杰哥2 天前
如何使用Postman做接口自动化测试及完美的可视化报告?
自动化测试·软件测试·python·测试工具·jenkins·postman·1024程序员节
软件测试小仙女3 天前
AI驱动的测试:Cypress的cy.prompt功能实践
自动化测试·软件测试·人工智能·测试工具·cypress·ai测试·测试计划
程序员小远3 天前
Appium+python+unittest搭建UI自动化框架
自动化测试·软件测试·python·测试工具·ui·appium·测试用例
mzhan0173 天前
Linux: network: wireshark:tcp 0.5 秒‘息停’发数据数据图表
网络·测试工具·wireshark
我的xiaodoujiao4 天前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 20--PO(POM) 设计模式和用例撰写
python·学习·测试工具·设计模式·pytest