当前位置: 首页 > article >正文

Selenium 中的 alert 处理

在 Selenium 中,alert 是浏览器的 JavaScript 弹窗(如 alert(), confirm(), prompt()),通常用于警告、确认操作或输入信息。Selenium 提供了 driver.switch_to.alert 来处理这些弹窗。

 

 


1. 获取 alert 对象

当页面弹出 alert 时,你需要先切换到该 alert,然后才能对其进行操作:

alert = driver.switch_to.alert

2. 常见操作

(1)获取 alert 文本

获取弹窗的文本内容:

text = alert.text
print(text)

(2)接受 alert

点击 “确定” 按钮:

alert.accept()

(3)取消 alert

点击 “取消” 按钮(适用于确认弹窗和输入弹窗):

alert.dismiss()

(4)输入文本

适用于输入类型的弹窗:

alert.send_keys("Hello, Selenium!")
alert.accept()  # 发送文本后点击“确定”

3. 等待 alert 出现

有时候 alert 可能不会立刻出现,因此可以使用 显式等待 让 Selenium 等待弹窗:

from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC

# 等待 `alert` 出现(最多 10 秒)
wait = WebDriverWait(driver, 10)
alert = wait.until(EC.alert_is_present())

# 获取文本并接受
print(alert.text)
alert.accept()

(在这种时候它就自己切换了!不用再alert = driver.switch_to.alert)

等价于

如果不用 WebDriverWait,手动 switch_to.alert 需要自己检查 alert 是否存在:

from selenium.common.exceptions import NoAlertPresentException
import time

time.sleep(3)  # 先等待几秒,假设 `alert` 可能延迟出现

try:
    alert = self.driver.switch_to.alert  # 手动切换到 `alert`
    print("弹窗内容:", alert.text)
    alert.accept()
except NoAlertPresentException:
    print("没有弹窗")

 

4. 常见 alert 相关异常

(1)NoAlertPresentException

selenium.common.exceptions.NoAlertPresentException: Message: no such alert

原因:试图操作 alert,但当前页面没有弹窗。

解决方案

  • 确保 alert 确实存在,可以先用 WebDriverWait 等待弹窗。
  • 使用 try-except 处理异常:
    try:
        alert = driver.switch_to.alert
        print(alert.text)
        alert.accept()
    except NoAlertPresentException:
        print("没有弹窗")
    

2)UnexpectedAlertPresentException

selenium.common.exceptions.UnexpectedAlertPresentException

原因:执行某个 Selenium 操作时,页面突然弹出 alert,导致操作失败。

解决方案

  • 先处理 alert,然后再执行 Selenium 操作:
try:
    alert = driver.switch_to.alert
    alert.accept()  # 先处理弹窗
except NoAlertPresentException:
    pass  # 没有弹窗就继续执行

# 继续执行 Selenium 操作
driver.find_element(By.CSS_SELECTOR, "#submit").click()

 处理 alert 关闭后仍然存在的问题

有些 alert 在关闭后,可能仍然会影响 Selenium 操作(比如 accept() 之后仍然报 alert 存在的错误)。

解决方案:执行 time.sleep(1) 或再次检查 alert 是否仍然存在

import time

alert = WebDriverWait(self.driver, 5).until(EC.alert_is_present())
alert.accept()

# 等待 alert 彻底消失
time.sleep(1)

try:
    self.driver.switch_to.alert  # 这里如果 alert 还在会报错
    print("alert 仍然存在")
except NoAlertPresentException:
    print("alert 已成功关闭")

alert 可能出现在 iframe

如果 alert嵌套在 iframe 内部,你可能需要先切换 iframe

# 先切换到 `iframe`
iframe = self.driver.find_element(By.CSS_SELECTOR, "iframe")
self.driver.switch_to.frame(iframe)

# 再等待 `alert`
alert = WebDriverWait(self.driver, 5).until(EC.alert_is_present())
alert.accept()

# 切回默认页面
self.driver.switch_to.default_content()

 5. 示例:处理登录失败的 alert

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
from selenium.common.exceptions import NoAlertPresentException

# 启动浏览器
driver = webdriver.Edge()
driver.get("https://example.com/login")

# 输入错误的用户名和密码
driver.find_element(By.CSS_SELECTOR, "#username").send_keys("")
driver.find_element(By.CSS_SELECTOR, "#password").send_keys("123456")
driver.find_element(By.CSS_SELECTOR, "#submit").click()

# 等待 `alert` 并获取文本
try:
    wait = WebDriverWait(driver, 10)
    alert = wait.until(EC.alert_is_present())
    print("弹窗内容:", alert.text)
    alert.accept()
except NoAlertPresentException:
    print("没有弹窗")

# 关闭浏览器
driver.quit()
  • driver.switch_to.alert 用于切换到 alert 并进行操作。
  • alert.text 获取弹窗内容,accept() 点击 确定dismiss() 点击 取消
  • send_keys() 仅适用于 prompt() 类型的弹窗。
  • 使用 WebDriverWait(driver, timeout).until(EC.alert_is_present()) 等待 alert 出现,避免 NoAlertPresentException


http://www.kler.cn/a/584599.html

相关文章:

  • MyBatis-Plus 分页查询接口返回值问题剖析
  • C++ 模板初阶总结
  • QT系列教程(16) 定时器事件
  • 为什么 Young GC 比 Full GC 快
  • 科技创新:改变生活的力量与未来趋势
  • nginx学习,URI,try_files
  • AWS Bedrock全托管接入国产大模型DeepSeek-R1[内涵免费使用DeepSeek-R1满血版]
  • 微博发布Q4及全年财报:微博成汽车手机新品营销主阵地
  • 【后端】【django】导出 API 文档的几种方法
  • 网络安全相关资源安全合规检查与整改计划‌
  • 【开源+代码解读】Search-R1:基于强化学习的检索增强大语言模型框架3小时即可打造个人AI-search
  • vue2双向绑定解析
  • 【 <一> 炼丹初探:JavaWeb 的起源与基础】之 JavaWeb 中的文件上传与下载:实现文件管理功能
  • STM32 HAL库实战:轻松实现串口通信驱动蓝牙模块与ESP8266开发
  • 数据中心安全建设方案,数据安全运营体系建设方案,信息中心安全解决方案(PPT)
  • 深度学习基础--CNN经典网络之“DenseNet”简介,源码研究与复现(pytorch)
  • RabbitMQ五种消息模型
  • 零成本搭建Calibre个人数字图书馆支持EPUB MOBI格式远程直读
  • 鸿蒙开发-一多开发之媒体查询功能
  • XSS跨站脚本攻击