pytest+uiautomation+allure+Excel 数据驱动桌面自动化

pytest+uiautomation+allure Excel 数据驱动桌面自动化

一、安装依赖

bash 复制代码
pip install pytest uiautomation allure-pytest openpyxl

openpyxl 专门读写xlsx 格式Excel

二、调整项目结构

Plain 复制代码
desktop_automation/
├── config/setting.py
├── data/
│   └── case_data.xlsx   # Excel测试数据
├── common/
│   └── read_excel.py    # 封装读取Excel工具类
├── page/
│   ├── base_page.py
│   └── notepad_page.py
├── testcase/test_notepad.py
├── conftest.py
└── pytest.ini

三、Excel 测试数据格式

新建 data/case\_data\.xlsx,工作表名:input\_data

case_name input_content expect_content
普通文本输入 桌面自动化 Excel 数据驱动 桌面自动化 Excel 数据驱动
特殊字符输入 123@#$ 测试 123@#$ 测试
空值输入
长文本输入 基于 pytest+uiautomation 做桌面 UI 自动化 基于 pytest+uiautomation 做桌面 UI 自动化

四、封装 Excel 读取工具 common/read\_excel.py(_excel.py)

python 复制代码
from openpyxl import load_workbook

class ReadExcel:
    @staticmethod
    def get_excel_data(file_path, sheet_name):
        """
        读取Excel用例数据,返回列表字典格式
        :param file_path: excel路径
        :param sheet_name: 工作表名
        :return: [{},{},...]
        """
        wb = load_workbook(filename=file_path)
        ws = wb[sheet_name]
        # 获取表头
        headers = [cell.value for cell in ws[1]]
        data_list = []
        # 遍历行数据,跳过表头
        for row in ws.iter_rows(min_row=2, values_only=True):
            row_dict = dict(zip(headers, row))
            data_list.append(row_dict)
        wb.close()
        return data_list

五、配置文件 config/setting.py(setting.py)

python 复制代码
# 被测应用
APP_PATH = "notepad.exe"
# 全局等待
IMPLICIT_WAIT = 3
# Excel数据路径
EXCEL_DATA_PATH = "./data/case_data.xlsx"
# Excel工作表名
EXCEL_SHEET = "input_data"

六、页面层代码不变

base\_page.py(_page.py) 不变

notepad\_page.py(_page.py) 不变

七、Excel 数据驱动测试用例 testcase/test\_notepad.py(_notepad.py)

python 复制代码
import pytest
from common.read_excel import ReadExcel
from page.notepad_page import NotePadPage
from config.setting import APP_PATH, EXCEL_DATA_PATH, EXCEL_SHEET

# 读取Excel所有测试数据
def get_excel_case_data():
    return ReadExcel.get_excel_data(EXCEL_DATA_PATH, EXCEL_SHEET)

class TestNotePadExcelDDT:
    def setup_class(self):
        self.page = NotePadPage()
        self.page.start_app(APP_PATH)

    def teardown_class(self):
        self.page.close_app()

    # Excel数据驱动参数化
    @pytest.mark.parametrize("case", get_excel_case_data(), ids=lambda x: x["case_name"])
    def test_input_by_excel(self, case):
        """Excel数据驱动-记事本输入测试"""
        in_text = case["input_content"]
        exp_text = case["expect_content"]

        self.page.input_edit_content(in_text)
        actual = self.page.get_edit_content()
        assert actual == exp_text, f"失败:预期{exp_text},实际{actual}"

八、conftest.py(conftest.py) 失败截图不变

python 复制代码
import pytest
import allure
import uiautomation as auto

@pytest.hookimpl(tryfirst=True, hookwrapper=True)
def pytest_runtest_makereport(item, call):
    outcome = yield
    report = outcome.get_result()
    if report.when == "call" and report.failed:
        try:
            img = auto.CaptureToImage()
            allure.attach(img, "失败截图", allure.attachment_type.PNG)
        except:
            pass

九、pytest.ini 不变

ini 复制代码
[pytest]
testpaths = testcase
python_files = test_*.py
python_classes = Test*
python_functions = test_*
addopts = -vs --alluredir=./report/temp --clean-alluredir

十、运行命令

bash 复制代码
# 执行用例
pytest

# 生成并打开allure报告
allure generate ./report/temp -o ./report/html --clean
allure open ./report/html

十一、扩展用法

  1. 增加用例状态控制
    Excel 新增列 is\_run,值为1执行,0跳过
    读取数据时过滤:
python 复制代码
data_list = [d for d in data_list if d.get("is_run") == 1]
  1. 区分正向 / 逆向用例

    Excel 加case\_type字段,用例内做不同业务逻辑

  2. 登录场景直接套用

    Excel 填账号、密码、预期结果,页面写登录方法即可

十二、注意事项

  1. 只支持 .xlsx,不支持老版.xls

  2. Excel 表头名称必须和代码取值字段完全一致

  3. 空单元格读取为None,代码可自行转为空字符串

相关推荐
李白你好16 小时前
AI Agent 架构的自动化渗透测试工具
运维·人工智能·自动化
实在智能RPA18 小时前
药企GMP合规自动化破局:实在Agent的功能完整度评估与落地实践
运维·人工智能·ai·自动化
Shota Kishi19 小时前
SLV 新增 allnodes-jito 支持:Solana 验证者多客户端运维与 AI agent 自动化解析
运维·自动化·区块链
是有头发的程序猿20 小时前
电商自动化实战:淘宝/天猫item_get商品详情API全量采集教程(Python源码)
java·python·自动化
V搜xhliang024621 小时前
临床科研新范式:从选题到投稿,AI智能体如何接管全流程?
运维·数据结构·人工智能·算法·microsoft·数据挖掘·自动化
Black蜡笔小新1 天前
自动化AI算法训练服务器DLTM零代码私有化一站式AI训练平台技术解析
人工智能·算法·自动化
米核AI易山1 天前
扣子工作流变量传递:6 个致命坑及解法
人工智能·自动化·coze·扣子工作流·米核ai易山
苏州邦恩精密1 天前
江苏蔡司3D扫描仪定制厂家:专业三维检测方案助力智能制造升级
人工智能·科技·机器学习·3d·自动化·制造
我命由我123451 天前
Excel - Excel 单元格格式同时设置日期时间
运维·学习·职场和发展·excel·求职招聘·职场发展·学习方法
志栋智能1 天前
轻量级 vs. 重平台:巡检超自动化的两种路径选择
运维·网络·人工智能·自动化