Python UI自动化 —— 关键字+excel表格数据驱动

步骤:

1. 对selenium进行二次封装,创建关键字的库

2. 准备一个表格文件来写入所有测试用例步骤

3. 对表格内容进行读取,使用映射关系来对用例进行调用执行

4. 执行用例

1. 对selenium进行二次封装,创建关键字的库

python 复制代码
from time import sleep
from selenium import webdriver


class Key:

    def __init__(self):
        self.driver = webdriver.Chrome()

    # 浏览器操作------------------------------------------------------------------
    def open(self, txt):
        # 打开网址
        self.driver.get(txt)
        # 最大化浏览器窗口
        self.driver.maximize_window()
        # 隐式等待10秒
        self.driver.implicitly_wait(10)

    def quit(self):
        # 退出浏览器
        self.driver.quit()

    def sleep(self, txt):
        # 强制等待
        sleep(txt)

    # 元素操作函数-----------------------------------------------------------------
    def input(self, txt, value, name="xpath"):
        # 输入
        el = self.driver.find_element(name, value)
        el.send_keys(txt)

    def click(self, value, name="xpath"):
        # 点击
        el = self.driver.find_element(name, value)
        el.click()

2. 创建一个表格,写入测试步骤

将表格放入项目任意路径下,记住路径,待会读取文件需要用到,我这里是放在这里

解释一下:(定位方法)为空,是因为关键字方法封装时,已经带上了默认参数

3. 写一个excel表格读取方法,对表格内容进行读取,使用映射关系来对用例进行调用执行。

看注释就明白是啥意思了

python 复制代码
import os
import openpyxl
from UI.Base.selenium_key import Key

# 获取该路径"../TestExampleExcel"模板下所有xlsx文件
filenames = os.listdir(r"../TestExampleExcel")

# 实例化驱动
wd = Key()

# 遍历所有xlsx文件
for i in filenames:
    excel = openpyxl.load_workbook(f'../TestExampleExcel/{i}')

    # 获取全部sheet页,遍历sheet页执行不同sheet页中的用例
    for name in excel.sheetnames:
        sheet = excel[name]
        print(f"正在执行{i}文件中的{name}用例")

        # 打印每一行表格数据
        for values in sheet.values:

            # 如果excel表格的第三列不是int类型,则不打印。
            if isinstance(values[2], int):
                data = {}
                data['name'] = values[4]
                data['value'] = values[5]
                data['txt'] = values[6]

                # 将字典中的None值给去除掉
                for k in list(data.keys()):
                    if data[k] is None:
                        del data[k]
                print(f"正在执行:{values[1]}")
                getattr(wd, values[3])(**data)

4. 执行用例

执行Excel文件读取方法即可

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

相关推荐
夜阳朔2 分钟前
Conda环境激活失效问题
人工智能·后端·python
m0_7231402324 分钟前
Python训练营-Day49
开发语言·python
蒙小萌199332 分钟前
苹果UI 设计
macos·ui·cocoa
北风toto1 小时前
python学习DataFrame数据结构
数据结构·python·学习
亿牛云爬虫专家1 小时前
微服务化采集平台:可扩展性与容错机制
python·微服务·架构·爬虫代理·扩展性·新浪财经·财经新闻
傻啦嘿哟1 小时前
Python爬虫动态IP代理报错全解析:从问题定位到实战优化
爬虫·python·tcp/ip
mit6.8241 小时前
[Meetily后端框架] Whisper转录服务器 | 后端服务管理脚本
c++·人工智能·后端·python
zhangfeng11331 小时前
python 数据分析 单细胞测序数据分析 相关的图表,常见于肿瘤免疫微环境、细胞亚群功能研究 ,各图表类型及逻辑关系如下
开发语言·python·数据分析·医学
柠檬豆腐脑2 小时前
Trae-Agent 内置工具深度解析
python·llm·agent
测试开发技术2 小时前
如何在 Pytest 中调用其他用例返回的接口参数?
面试·自动化·pytest·接口·接口测试·api测试