Python3 Selenium 自动化测试从入门到实战开发流程

张开发
2026/4/14 10:00:26 15 分钟阅读

分享文章

Python3 Selenium 自动化测试从入门到实战开发流程
本章学习目标帮助零基础 / 初级测试工程师快速掌握 Python3Selenium 自动化测试从环境搭建到项目实战全覆盖可直接用于接口 / UI 自动化工作落地。一、引言为什么 Selenium 自动化测试如此重要在软件迭代加速、回归频繁的今天Python3Selenium UI 自动化测试已成为测试工程师必备核心技能能大幅降低重复劳动、提升测试覆盖率与发布效率。1.1 背景与意义核心认知Selenium 是 Web 自动化事实标准搭配 Python 简洁语法可快速实现浏览器模拟、元素操作、断言验证、报告生成。手工测试重复度高、易出错、回归慢自动化可 7×24 小时执行支持多浏览器 / 多平台行业主流互联网 / 金融 / 企业级项目普遍采用 Selenium 栈1.2 本章结构概览plaintext环境搭建 → 核心API → 元素定位 → 常用操作 → 实战项目 → 最佳实践 → 总结展望二、核心概念解析2.1 基本定义概念一Selenium 核心组件表格组件说明作用Selenium WebDriver核心驱动控制浏览器执行操作Selenium IDE录制工具快速生成脚本入门用Selenium Grid分布式多机器 / 多浏览器并行执行概念二Python3Selenium 优势语法简洁入门快丰富第三方库unittest/pytest/allure跨浏览器Chrome/Firefox/Edge跨平台Windows/Mac/Linux2.2 关键术语解释⚠️基础术语元素定位找到页面按钮 / 输入框 / 链接的方式显式等待等待元素满足条件再执行避免报错隐式等待全局等待元素加载断言判断结果是否符合预期验证用例2.3 技术架构概览plaintext┌─────────────────────────────────────────┐ │ 用例层 (Test Case) │ unittest/pytest 测试用例、断言 ├─────────────────────────────────────────┤ │ 驱动层 (WebDriver) │ ChromeDriver/GeckoDriver 浏览器驱动 ├─────────────────────────────────────────┤ │ 操作层 (Action) │ 点击、输入、切换、截图、获取文本 ├─────────────────────────────────────────┤ │ 报告层 (Report) │ Allure/HTMLTestRunner 测试报告 └─────────────────────────────────────────┘三、技术原理深入3.1 核心技术原理技术一环境一键搭建python运行# 1. 安装Selenium库 pip install selenium4.15.0 # 2. 安装浏览器驱动管理库 pip install webdriver-manager技术二最简启动示例python运行from selenium import webdriver from selenium.webdriver.chrome.service import Service from webdriver_manager.chrome import ChromeDriverManager import time # 自动安装并启动Chrome driver webdriver.Chrome(serviceService(ChromeDriverManager().install())) # 打开网页 driver.get(https://www.baidu.com) # 窗口最大化 driver.maximize_window() # 等待2秒 time.sleep(2) # 关闭浏览器 driver.quit()技术三元素定位Selenium4 推荐写法python运行from selenium.webdriver.common.by import By # 常用定位方式 driver.find_element(By.ID, kw) # ID driver.find_element(By.NAME, wd) # Name driver.find_element(By.CLASS_NAME, s_ipt) # Class driver.find_element(By.XPATH, //input[idkw]) # XPath driver.find_element(By.CSS_SELECTOR, #kw) # CSS driver.find_element(By.LINK_TEXT, 新闻) # 链接文本3.2 数据交互机制标准自动化流程plaintext打开浏览器 → 进入页面 → 定位元素 → 执行操作 → 断言结果 → 生成报告 → 关闭浏览器完整交互封装python运行class BasePage: def __init__(self, driver): self.driver driver # 打开页面 def open_url(self, url): self.driver.get(url) # 输入内容 def input_text(self, locator, text): ele self.driver.find_element(*locator) ele.clear() ele.send_keys(text) # 点击元素 def click_ele(self, locator): self.driver.find_element(*locator).click() # 获取文本 def get_text(self, locator): return self.driver.find_element(*locator).text3.3 等待与异常处理python运行from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC # 显式等待最多10秒直到元素可点击 wait WebDriverWait(driver, 10) wait.until(EC.element_to_be_clickable((By.ID, su)))四、实践应用指南4.1 应用场景分析✅核心场景登录自动化账号密码输入、验证登录状态表单自动化输入、下拉、单选、复选、提交搜索自动化关键词输入、结果校验流程自动化下单、支付、退款、订单查询回归测试版本更新自动执行用例4.2 实施步骤详解步骤 1需求分析测试页面 / 功能点确定用例步骤与预期结果确定元素定位方案步骤 2技术选型plaintext- 语言Python 3.8 - 框架Selenium 4.x pytest - 驱动webdriver-manager 自动管理 - 报告Allure 2.0 - 设计模式Page Object Model (POM)步骤 3开发实现表格任务内容时长环境搭建PythonSelenium 驱动0.5 天基础语法定位 / 操作 / 等待 / 断言1 天POM 封装基类 页面类 用例类2 天项目实战完整业务流程自动化2 天调试优化报错处理、稳定性提升1 天4.3 最佳实践分享最佳实践一PO 模式页面元素与用例分离便于维护减少重复代码适合多人协作最佳实践二等待优先禁用time.sleep()硬等待优先用显式等待避免因加载慢导致用例失败五、案例分析5.1 成功案例百度搜索自动化实战背景实现打开百度→输入关键词→点击搜索→校验结果完整代码python运行import pytest from selenium import webdriver from selenium.webdriver.chrome.service import Service from webdriver_manager.chrome import ChromeDriverManager from selenium.webdriver.common.by import By from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC class TestBaiduSearch: def setup_class(self): self.driver webdriver.Chrome(serviceService(ChromeDriverManager().install())) self.driver.maximize_window() self.driver.implicitly_wait(10) def test_baidu_search(self): # 打开百度 self.driver.get(https://www.baidu.com) # 输入Selenium wait WebDriverWait(self.driver, 10) input_ele wait.until(EC.presence_of_element_located((By.ID, kw))) input_ele.send_keys(Selenium自动化测试) # 点击搜索 self.driver.find_element(By.ID, su).click() # 断言标题包含关键词 assert Selenium自动化测试 in self.driver.title def teardown_class(self): self.driver.quit() if __name__ __main__: pytest.main([-v, test_baidu.py])实施效果表格指标手工自动化单次执行时间60 秒10 秒回归覆盖率60%95%人力成本高低稳定性易出错稳定可靠5.2 失败教训❌常见踩坑直接用time.sleep(2)网络波动就失败不做等待元素未加载就操作用例无断言执行通过但功能错误不关闭浏览器资源泄漏解决方案统一用显式等待每条用例必须加断言用setup/teardown管理浏览器生命周期加入异常捕获与截图六、常见问题解答6.1 技术问题Q1浏览器驱动版本不匹配 用webdriver-manager自动管理无需手动下载。Q2元素定位不到检查是否在 iframe 中检查是否动态 ID/Class改用 XPath/CSS 稳定定位增加等待时间Q3用例不稳定、偶尔失败去掉time.sleep用显式等待避免用绝对 XPath用 PO 模式降低耦合6.2 应用问题Q4如何生成美观测试报告bash运行# 安装 pip install allure-pytest # 执行用例并生成数据 pytest --alluredir./report # 启动报告服务 allure serve ./reportQ5如何实现无头模式不打开浏览器python运行from selenium.webdriver.chrome.options import Options options Options() options.add_argument(--headlessnew) # 无头模式 driver webdriver.Chrome(optionsoptions)七、未来发展趋势7.1 技术趋势表格趋势说明时间AI 自动化AI 自动生成定位与用例1-2 年云原生执行云端分布式并行测试已普及Cypress 替代前端轻量化自动化崛起2-3 年低代码平台可视化生成自动化用例进行中7.2 职业发展表格阶段学习重点时长入门环境 语法 基础用例1 个月进阶POM 数据驱动 报告2 个月专业接口 UI 一体化自动化3-6 个月专家平台化、持续集成 CI/CD6-12 个月八、本章小结8.1 核心要点回顾✅ 本章完整覆盖环境搭建PythonSelenium 一键配置核心 API定位、操作、等待、断言设计模式PO 模式最佳实践实战案例可直接落地的搜索自动化问题排查常见报错与稳定化方案职业路径从入门到自动化专家8.2 学习建议先跑通示例再理解原理每天写 1 个用例快速形成肌肉记忆用 PO 重构代码养成工程化思维结合项目实战学以致用最有效九、课后练习基础练习实现 CSDN 登录自动化脚本实战练习用 PO 模式封装一个登录页面综合练习完成 “登录→搜索→断言” 完整流程报告练习用 Allure 生成可视化测试报告十、参考资料Selenium 官方文档https://www.selenium.dev/documentation/Python 官方文档https://docs.python.org/3/pytest 文档https://docs.pytest.org/Allure 报告https://docs.qameta.io/allure/

更多文章