基于 Python 的 Selenium 自动化测试
第一部分:基础入门
第1章:Selenium简介
1.1 自动化测试的意义
1.2 Selenium的组成与功能
1.3 Selenium的应用场景
第2章:环境搭建
2.1 安装Python环境
2.2 安装Selenium库
2.3 下载并配置浏览器驱动
2.4 验证环境配置
第3章:第一个Selenium脚本
3.1 初始化WebDriver
3.2 打开网页并执行基本操作
3.3 关闭浏览器
第二部分:核心功能
第4章:元素定位
4.1 常见定位策略(ID、Class、Name、XPath、CSS Selector等)
4.2 定位一组元素
4.3 动态元素定位技巧
第5章:浏览器操作
5.1 控制浏览器窗口(大小、位置、全屏等)
5.2 页面导航(前进、后退、刷新)
5.3 多窗口切换
5.4 多表单切换
第6章:元素操作
6.1 输入文本与清空输入框
6.2 点击操作
6.3 鼠标悬停、右键点击、双击
6.4 键盘操作(组合键、特殊键)
第7章:等待机制
7.1 显式等待与隐式等待
7.2 设置页面加载策略
第8章:高级操作
8.1 滚动页面
8.2 调用JavaScript
8.3 文件上传与下载
8.4 警告框处理
第三部分:实战应用
第9章:测试框架设计
9.1 测试框架的基本结构
9.2 页面对象模式(POM)
9.3 使用pytest进行测试
第10章:实战案例
10.1 电商网站自动化测试
10.2 登录测试
10.3 商品浏览与购物车操作
10.4 结账流程测试
第11章:数据驱动测试
11.1 数据驱动的概念
11.2 使用CSV/Excel文件进行数据驱动
11.3 参数化测试用例
第四部分:高级技巧
第12章:性能优化
12.1 减少测试执行时间
12.2 使用Selenium Grid进行分布式测试
第13章:反检测技术
13.1 使用stealth.min.js
13.2 避免被检测到的技巧
第14章:处理动态内容
14.1 动态页面加载的处理
14.2 图片验证码的处理
第五部分:附录
附录A:常见问题与解决方法
附录B:Selenium官方文档资源
附录C:Python常用库与工具
-
+
首页
11.2 使用CSV/Excel文件进行数据驱动
##### 1. **使用CSV文件** CSV(Comma-Separated Values)文件是一种常见的数据存储格式,适合存储结构化数据。Python的`csv`模块可以方便地读取CSV文件。 **示例:CSV文件内容(`test_data.csv`)** csv复制 ```csv username,password,expected_result standard_user,secret_sauce,success locked_out_user,secret_sauce,failure invalid_user,invalid_password,failure ``` **读取CSV文件并进行测试** Python复制 ```python import csv import pytest from pages.login_page import LoginPage @pytest.fixture def browser(): driver = webdriver.Chrome() yield driver driver.quit() def get_test_data(): test_data = [] with open("test_data.csv", "r") as file: reader = csv.DictReader(file) for row in reader: test_data.append((row["username"], row["password"], row["expected_result"])) return test_data @pytest.mark.parametrize("username,password,expected_result", get_test_data()) def test_login(browser, username, password, expected_result): login_page = LoginPage(browser) login_page.open() login_page.login(username, password) if expected_result == "success": assert "inventory.html" in browser.current_url else: error_message = browser.find_element(By.CSS_SELECTOR, "h3[data-test='error']").text assert "Epic sadface" in error_message ``` ------ ##### 2. **使用Excel文件** Excel文件是一种更复杂的数据存储格式,适合存储更复杂的数据结构。Python的`openpyxl`库可以方便地读取Excel文件。 **安装`openpyxl`** bash复制 ```bash pip install openpyxl ``` **示例:Excel文件内容(`test_data.xlsx`)** | username | password | expected_result | | --------------- | ---------------- | --------------- | | standard_user | secret_sauce | success | | locked_out_user | secret_sauce | failure | | invalid_user | invalid_password | failure | **读取Excel文件并进行测试** Python复制 ```python import pytest from openpyxl import load_workbook from pages.login_page import LoginPage @pytest.fixture def browser(): driver = webdriver.Chrome() yield driver driver.quit() def get_test_data(): test_data = [] workbook = load_workbook("test_data.xlsx") sheet = workbook.active for row in sheet.iter_rows(min_row=2, values_only=True): username, password, expected_result = row test_data.append((username, password, expected_result)) return test_data @pytest.mark.parametrize("username,password,expected_result", get_test_data()) def test_login(browser, username, password, expected_result): login_page = LoginPage(browser) login_page.open() login_page.login(username, password) if expected_result == "success": assert "inventory.html" in browser.current_url else: error_message = browser.find_element(By.CSS_SELECTOR, "h3[data-test='error']").text assert "Epic sadface" in error_message ``` ------
黄老师
2025年1月23日 16:20
转发文档
收藏文档
上一篇
下一篇
手机扫码
复制链接
手机扫一扫转发分享
复制链接
Markdown文件
分享
链接
类型
密码
更新密码