ui自动化结合unittest框架引入Excel文件与parameterized 方法实现参数化

在自动化测试的过程中我们可以在本地引入Excel文件与parameterized方法结合实现参数化,这样大大提高了代码的可读性,更加方便的维护管理我们的测试数据了。下面请看博主一一介绍方法。

1.在使用Excel文件实现参数化前,老生常谈我们先安装它的库,打开cmd输入:

pip install xlrd

2.下面请看博主来介绍xlrd的基本用法。

首先先导包。

import xlrd

我们就继续已qq邮箱为例子啦,下面请看文件内容。

ui自动化结合unittest框架引入Excel文件与parameterized 方法实现参数化_第1张图片

打来Excel文件,这里参数是你文件路径

excel = xlrd.open_workbook('C:\\Users\hujian\Desktop\hujian.xlsx')

获取工作表,这里方法有多种,博主只介绍通过名称获取的方法,掌握这种就够啦。

table = excel.sheet_by_name('Sheet1')  #通过名称获取工作表

获取总行数和总列数的方法。

hang = table.nrows    #显示总行数
lie = table.ncols     #显示总列数

获取第一列所有的值获取一列所有的值,python会将其依次用列表的方式打印出来。

hu = table.row_values(0) #获取一行的所有值
jiang = table.col_values(0)#获取第一列的所有值

获取一行一列的值。

x = table.cell_value(0,0)#获取第一行第一列的值

大家在测试工作中能用到的方法基本都在这里了。但用Excel文件导数据在python中会出现一个问题,就是Excel表中的所有数字在python打印出来时都默认变为浮点型。实际操作过程中肯定有很多小伙伴会遇到。那这样改怎么办呢,下面请看博主操作。哈哈哈

选中需要使用整型打印出来数据,选中文本格式。

ui自动化结合unittest框架引入Excel文件与parameterized 方法实现参数化_第2张图片

 单元框左上角出现蓝色三角小方框就可啦。这样输入框我们输入啥就显示啥了。

下面我们将该方法写到unittest框架中,

excel = xlrd.open_workbook('C:\\Users\hujian\Desktop\hujian.xlsx')
table = excel.sheet_by_name('Sheet1')  # 通过名称获取工作表
hang = table.nrows  # 显示总行数
# lie = table.ncols    #显示总列数
weijia = []    #定义一个空的列表
for i in range(1, hang):  #从列表第二行开始遍历,
    weijia.append(table.row_values(i))#将遍历的数据全部写到weijia列表中
    print(weijia)

打印一下看下效果。刚好符合parameterized()方法对于参数化的格式要求。

后面我们直接将weijia列表放到parameterized()方法中。

    excel = xlrd.open_workbook('C:\\Users\hujian\Desktop\hujian.xlsx')
    table = excel.sheet_by_name('Sheet1')  # 通过名称获取工作表
    hang = table.nrows  # 显示总行数
    # lie = table.ncols    #显示总列数
    weijia = []    #定义一个空的列表
    for i in range(1, hang):  #从列表第二行开始遍历,
        weijia.append(table.row_values(i))   #将遍历的数据全部写到weijia列表中
    @parameterized.expand(weijia)   #添加装饰器中,装饰器的最外层必须是列表形式的。列表内可以是元组或者列表

好了这样就实现unittest框架结合Excel表格实现参数化了。

想要完整源码的小伙伴,关注留言,哈哈哈,人气太低啦。写的好辛苦。

你可能感兴趣的:(ui自动化结合unittest框架引入Excel文件与parameterized 方法实现参数化)