python selenium - 利用excel实现参数化

前言

在进行软件测试或设计自动化测试框架时,一个比可避免的过程就是: 参数化,在利用python进行自动化测试开发时,通常会使用excel来做数据管理,利用xlrd、xlwt开源包来读写excel。

环境安装

首先在命令行下安装xlrd、xlwt

pip install xlrd pip install xlwt

一个简单的读写示例

让我们先看一个简单的excel读写示例,示例代码功能,从表1中读取数据。

excel数据表如图所示

demo.xlsx

1、读取代码示例

#_*_ coding:utf-8 _*_ __author__ = '苦叶子' import xlrd if __name__ == '__main__': # excel文件全路径 xlPath = "C:\\Users\\lyy\\Desktop\\demo.xlsx" # 用于读取excel xlBook = xlrd.open_workbook(xlPath) # 获取excel工作簿数 count = len(xlBook.sheets()) print u"工作簿数为: ", count # 获取 表 数据的行列数 table = xlBook.sheets()[0] nrows = table.nrows ncols = table.ncols print u"表数据行列为(%d, %d)" % (nrows, ncols) # 循环读取数据 for i in xrange(0, nrows): rowValues = table.row_values(i) # 按行读取数据 # 输出读取的数据 for data in rowValues: print data, " ", print ""

运行效果如图

运行结果

2、写excel示例代码

#_*_ coding:utf-8 _*_ __author__ = '苦叶子' import xlwt import random if __name__ == '__main__': # 注意这里的excel文件的后缀是xls 如果是xlsx打开是会提示无效 newPath = unicode("C:\\Users\\lyy\\Desktop\\demo_new.xls", "utf8") wtBook = xlwt.Workbook() # 新增一个sheet sheet = wtBook.add_sheet("sheet1", cell_overwrite_ok=True) # 写入数据头 headList = [u'序号', u'数据1', u'数据2', u'数据3'] rowIndex = 0 col = 0 # 循环写 for head in headList: sheet.write(rowIndex, col, head) col = col + 1 # 写入10行 0-99的随机数据

for index in xrange(1, 11): for col in xrange(1, 4): data = random.randint(0,99) sheet.write(index, 0, index) # 写序号 sheet.write(index, col, data) # 写数据 print u"写第[%d]行数据" % index

# 保存 wtBook.save(newPath)

运行结果如图

写excel结果

结束语

这里只是简单的对xlrd、xlwt模块的应用演示,对于实际做自动化测试过程中,需要封装一个通用的excel解析类,以便提高复用性和降低维护成本。

在实际应用中,我们通常需要对表格进行合并、样式设置等等系列动作,请参考官方文档,进行更深入的学习研究

python excel官网: http://www.python-excel.org/

原文发布于微信公众号 - 开源优测(DeepTest)

原文发表时间:2017-12-03

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏AzMark

Python 学习之进程与线程 「 上 」

进程:对于操作系统来说,一个任务就是一个进程(Process),比如打开一个浏览器(任务)就是启动一个浏览器进程。进程是系统中程序执行和资源分配的基本单位,每个...

7620
来自专栏北京马哥教育

rsync - Linux下进行文件同步命令

rsync是Linux下进行文件同步到一个命令,可以同步两台计算机到文件与目录,利用查找文件中到不同块以减少数据传输。也可以在一台电脑到不同目录间同步,比如可以...

57160
来自专栏用户2442861的专栏

linux工作中常用文件操作命令

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/haluoluo211/article/d...

27720
来自专栏开源优测

python selenium2示例 - 利用excel实现参数化

前言 在进行软件测试或设计自动化测试框架时,一个比可避免的过程就是: 参数化,在利用python进行自动化测试开发时,通常会使用excel来做数据管理,利用xl...

33070
来自专栏开源优测

python selenium - 利用excel实现参数化

前言 在进行软件测试或设计自动化测试框架时,一个比可避免的过程就是: 参数化,在利用python进行自动化测试开发时,通常会使用excel来做数据管理,利用xl...

38880
来自专栏无题

分布式缓存一致性hash算法

在设计分布式缓存集群的时候,需要考虑集群的伸缩性,也就是当向集群中增加服务器的时候,要尽量减小对集群的影响,而一致性hash算法就是用来解决集群伸缩性。 当服...

34820
来自专栏腾讯云TStack专栏

对象存储,了解一下

? 对象存储,通常指 S3 (Simple Storage Service) 服务,由AWS提供公有云服务,而 Ceph 也可以提供兼容 S3 协议的对象存储...

90920
来自专栏文渊之博

优化SQLServer——表和分区索引

概念:            简单地说,分区是将大型的对象(如表)分成更小的且易于管理的小块。分区的基本单位是行,需要注意的是与分区视图不同的地方时,分区必须位...

193100
来自专栏个人分享

Redis简介及3.0.2编译安装

Redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(...

10120
来自专栏编程微刊

微信小程序从零开始开发步骤(七)引入外部js 文件

26240

扫码关注云+社区

领取腾讯云代金券