在自动化测试的过程中我们可以在本地引入Excel文件与parameterized方法结合实现参数化,这样大大提高了代码的可读性,更加方便的维护管理我们的测试数据了。下面请看博主一一介绍方法。
1.在使用Excel文件实现参数化前,老生常谈我们先安装它的库,打开cmd输入:
pip install xlrd
2.下面请看博主来介绍xlrd的基本用法。
首先先导包。
import xlrd
我们就继续已qq邮箱为例子啦,下面请看文件内容。
打来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打印出来时都默认变为浮点型。实际操作过程中肯定有很多小伙伴会遇到。那这样改怎么办呢,下面请看博主操作。哈哈哈
选中需要使用整型打印出来数据,选中文本格式。
单元框左上角出现蓝色三角小方框就可啦。这样输入框我们输入啥就显示啥了。
下面我们将该方法写到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表格实现参数化了。
想要完整源码的小伙伴,关注留言,哈哈哈,人气太低啦。写的好辛苦。