Selenium - 设置元素等待及加载策略

7月18日资源分享:

耿直哥三部曲全------机器学习,强化学习,深度学习

链接: https://pan.baidu.com/s/1c_eVVeqCZmB6zszHt6ZXiw?pwd=tf2a

在使用Selenium进行网页自动化测试时,一个常见的问题是页面加载速度和元素的可见性问题。为了确保脚本的稳定性和可靠性,我们需要设置合适的等待策略来处理这些问题。本文将详细介绍Selenium中常用的元素等待和加载策略,并提供详细的代码案例。

1. 为什么需要等待策略?

网页的加载速度和元素的加载时间可能会因网络状况、服务器响应时间等因素而变化。如果不考虑这些因素,直接操作网页元素可能会导致​​NoSuchElementException​​、​​ElementNotVisibleException​​等错误。因此,合理的等待策略是确保Selenium脚本稳定运行的关键。

2. Selenium中的等待类型

Selenium提供了三种主要的等待方式:

  1. 隐式等待(Implicit Wait)
  2. 显式等待(Explicit Wait)
  3. 流式等待(Fluent Wait)

2.1 隐式等待(Implicit Wait)

隐式等待告诉Selenium WebDriver在查找一个元素时,如果元素没有立即出现,则等待一段时间。在等待的这段时间内,Selenium WebDriver会每隔一段时间重新尝试查找元素。

复制代码
from selenium import webdriver

driver = webdriver.Chrome()
driver.get("http://example.com")

# 设置隐式等待
driver.implicitly_wait(10)  # 等待最长10秒

# 尝试查找元素
element = driver.find_element_by_id("myElement")

2.2 显式等待(Explicit Wait)

显式等待是在代码中指定条件的等待,可以在指定的时间内等待某个条件成立。最常用的显式等待是WebDriverWait。

复制代码
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

driver = webdriver.Chrome()
driver.get("http://example.com")

# 设置显式等待
wait = WebDriverWait(driver, 10)
element = wait.until(EC.presence_of_element_located((By.ID, "myElement")))

print(element.text)

2.3 流式等待(Fluent Wait)

流式等待是显式等待的一种扩展,允许我们定义等待的最大时长、轮询间隔以及忽略的异常类型。

复制代码
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.webdriver.support.ui import FluentWait
from selenium.common.exceptions import NoSuchElementException
import time

driver = webdriver.Chrome()
driver.get("http://example.com")

# 设置流式等待
wait = FluentWait(driver)
wait.with_timeout(10)  # 最长等待10秒
wait.polling_every(2)  # 每2秒检查一次
wait.ignoring(NoSuchElementException)

element = wait.until(lambda x: x.find_element_by_id("myElement"))

print(element.text)

3. 综合案例:使用等待策略进行页面操作

接下来,我们将结合上述等待策略编写一个综合案例。在这个案例中,我们将访问一个模拟登录页面,输入用户名和密码,并点击登录按钮。我们将使用显式等待确保页面元素在操作之前已经加载完成。

示例网页结构

假设我们有一个简单的登录页面,其HTML结构如下:

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Login Page</title>
</head>
<body>
    <form id="loginForm">
        <input type="text" id="username" name="username" placeholder="Username">
        <input type="password" id="password" name="password" placeholder="Password">
        <button id="loginButton">Login</button>
    </form>
    <div id="message"></div>
</body>
</html>

Selenium脚本

复制代码
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

# 初始化WebDriver
driver = webdriver.Chrome()
driver.get("http://localhost:8000")  # 假设本地启动了一个服务

try:
    # 显式等待用户名输入框加载完成
    wait = WebDriverWait(driver, 10)
    username_field = wait.until(EC.presence_of_element_located((By.ID, "username")))

    # 输入用户名
    username_field.send_keys("testuser")

    # 显式等待密码输入框加载完成
    password_field = wait.until(EC.presence_of_element_located((By.ID, "password")))

    # 输入密码
    password_field.send_keys("password123")

    # 显式等待登录按钮加载完成
    login_button = wait.until(EC.element_to_be_clickable((By.ID, "loginButton")))

    # 点击登录按钮
    login_button.click()

    # 显式等待登录结果消息显示
    message = wait.until(EC.presence_of_element_located((By.ID, "message")))

    print("Login message:", message.text)

finally:
    # 关闭浏览器
    driver.quit()

运行脚本

确保在本地启动一个包含上述HTML结构的服务,然后运行上述Selenium脚本。该脚本将自动打开浏览器,访问指定的URL,输入用户名和密码,并点击登录按钮。通过显式等待确保每一步操作中的元素都已加载完成。

4. 总结

等待策略在Selenium自动化测试中至关重要,可以有效提高脚本的稳定性和可靠性。本文介绍了隐式等待、显式等待和流式等待的用法,并通过一个综合案例展示了如何在实际项目中应用这些等待策略。希望这篇博客能帮助你更好地理解和使用Selenium中的等待机制。如果你有更多的等待策略或技巧,欢迎在评论区分享!

相关推荐
Wpa.wk40 分钟前
自动化测试 - 文件上传 和 弹窗处理
开发语言·javascript·自动化测试·经验分享·爬虫·python·selenium
少云清1 小时前
【接口测试】4_Postman _全局变量和环境变量
测试工具·postman
卓码软件测评2 小时前
CMA/CNAS软件测评机构:【Gatling数据库性能关联测试JDBC连接和SQL执行时间监控】
数据库·sql·测试工具·性能优化·测试用例
mike04124 小时前
Eclipse+maven+selenium自动化测试用例入门
selenium·eclipse·maven
2501_9240641118 小时前
2025年接口错误自动分析工具对比与性能测试平台选型指南
测试工具·性能优化·数据可视化
UTP协同自动化测试1 天前
UTP测试系统为家电及智能家居产品打造高效、合规、体验至上的验证体系
功能测试·物联网·测试工具·视觉检测·压力测试·模块测试·测试覆盖率
慧都小项1 天前
JAVA自动化测试平台Parasoft Jtest 插件Eclipse/IDEA安装教程
java·软件测试·测试工具·eclipse·intellij-idea
少云清1 天前
【接口测试】1_Postman _Postman环境搭建
测试工具·postman
程序员杰哥1 天前
如何使用Postman做接口自动化测试?
自动化测试·软件测试·python·测试工具·测试用例·接口测试·postman
天才测试猿1 天前
Jmeter 命令行压测&生成HTML测试报告
自动化测试·软件测试·python·测试工具·jmeter·职场和发展·jenkins