Python自动化之数据驱动让你的脚本简洁10倍【推荐】


Posted in Python onJune 04, 2019

Python自动化之数据驱动让你的脚本简洁10倍【推荐】

前言

数据驱动是一种思想,让数据和代码进行分离,比如爬虫时,我们需要分页爬取数据时,我们往往把页数 page 参数化,放在 for 循环 range 中,假如没有 range 这个自带可以生产数字序列的方法可以用,我们是不是得手动逐个添加?

Python自动化之数据驱动让你的脚本简洁10倍【推荐】

现实场景中就存在大量这样的例子,比如我之前写的爬取上海各地区房租情况的时候,对地区进行遍历的时候,为了偷懒,我直接把这些地区的拼音全称放在了列表里,组合成各地区房源的链接。最后文章写完了,有读者反馈,少了徐汇区的统计数据。这种小数量的数据都出现了纰漏,可想而知,对于大量的数据,怎么保证数据的完整和准确性?我们需要把两者分离,数据专门储存在特定文件(比如 Excel 文件)。

Python自动化之数据驱动让你的脚本简洁10倍【推荐】

举一个小栗子:登录流程,在测试的时候,除了测试登录成功的场景,我们往往需要测到各种登录异常的场景。

写几条很常见的案例如下:

Python自动化之数据驱动让你的脚本简洁10倍【推荐】

比如上面写了 5 条案例,数据和脚本不做分离的话,我们写自动化测试脚本需要写 5 条。

Python自动化之数据驱动让你的脚本简洁10倍【推荐】

5 条案例中,脚本都是基本一样的,只是输入框输入的数据不一样罢了。

Python自动化之数据驱动让你的脚本简洁10倍【推荐】

数据分离

我们完全可以把数据存储在 Excel 表中,我们通过循环读取 Excel 表中的数据来实现一条脚本执行多条数据。

我们先封装一个操作 Excel 文件的类,需要先安装导入包 openpyxl。

我们用这个库可以做一下功能:读取表格数据、保存执行结果。

我们先在类下写一个打开 Excel 文件的初始化方法,构造方法的作用是,当类被实例化后,会立即调用构造方法。

Python自动化之数据驱动让你的脚本简洁10倍【推荐】

读取表格数据

然后我们写一个读取 Excel 数据的方法,读取数据后返回数据列表,以便之后调用获取对应的数据,因为第 1 列数据是序号,所以直接返回第 2 列之后的数据。

Python自动化之数据驱动让你的脚本简洁10倍【推荐】

保存执行结果

实际结果和预期结果对比后,我们需要标记执行结果是 pass 或者 fail,我们需要保存结果,保存到对应的单元格中。

Python自动化之数据驱动让你的脚本简洁10倍【推荐】

我们看看我们的案例格式:

Python自动化之数据驱动让你的脚本简洁10倍【推荐】

这样的话,我们脚本就不用写 5 条了,调用 Excel 文件的数据,循环执行案例即可,不仅逻辑清晰,还方便了后期的维护。

Python自动化之数据驱动让你的脚本简洁10倍【推荐】

这样,测试数据和脚本分离后,不同的测试数据用不同的 Excel 文件保存即可。

吃饭时或者下班时执行下测试脚本,吃完饭后或者第二天上班时,查看下 Excel 里的执行结果,有 fail 再手动看看能否复现,是不是很高效?

总结

以上所述是小编给大家介绍的Python自动化之数据驱动让你的脚本简洁10倍,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
python实现ip查询示例
Mar 26 Python
python+Django+apache的配置方法详解
Jun 01 Python
Python cookbook(数据结构与算法)在字典中将键映射到多个值上的方法
Feb 18 Python
儿童学习python的一些小技巧
May 27 Python
Python中按值来获取指定的键
Mar 04 Python
详解Python中的测试工具
Jun 09 Python
使用Python脚本zabbix自定义key监控oracle连接状态
Aug 28 Python
Python %r和%s区别代码实例解析
Apr 03 Python
基于Python实现体育彩票选号器功能代码实例
Sep 16 Python
基于python模拟bfs和dfs代码实例
Nov 19 Python
Python类型转换的魔术方法详解
Dec 23 Python
python爬取豆瓣电影TOP250数据
May 23 Python
pandas DataFrame索引行列的实现
Jun 04 #Python
深入浅析Python中的迭代器
Jun 04 #Python
Python学习笔记之读取文件、OS模块、异常处理、with as语法示例
Jun 04 #Python
Python利用sqlacodegen自动生成ORM实体类示例
Jun 04 #Python
Python批量生成幻影坦克图片实例代码
Jun 04 #Python
python和mysql交互操作实例详解【基于pymysql库】
Jun 04 #Python
Python获取基金网站网页内容、使用BeautifulSoup库分析html操作示例
Jun 04 #Python
You might like
header中Content-Disposition的作用与使用方法
2012/06/13 PHP
php+mysqli使用面向对象方式查询数据库实例
2015/01/29 PHP
PHP加密解密类实例代码
2016/07/20 PHP
PHP 实现文件压缩解压操作的方法
2019/06/14 PHP
jQuery each()方法的使用方法
2010/03/18 Javascript
JavaScript游戏之优化篇
2010/11/08 Javascript
调试Node.JS的辅助工具(NodeWatcher)
2012/01/04 Javascript
JavaScript中instanceof与typeof运算符的用法及区别详细解析
2013/11/19 Javascript
js中iframe调用父页面的方法
2014/10/30 Javascript
javascript实现图片循环渐显播放的方法
2015/02/24 Javascript
Bootstrap4一次重大更新 几乎涉及每行代码
2016/05/16 Javascript
探讨AngularJs中ui.route的简单应用
2016/11/16 Javascript
node安装--linux下的快速安装教程
2017/03/21 Javascript
Angular.JS中的this指向详解
2017/05/17 Javascript
微信小程序图片自适应支持多图实例详解
2017/06/21 Javascript
Koa2微信公众号开发之本地开发调试环境搭建
2018/05/16 Javascript
Vue中的v-for指令不起效果的解决方法
2018/09/27 Javascript
实例讲解vue源码架构
2019/01/24 Javascript
JavaScript实现随机五位数验证码
2019/09/27 Javascript
vue 路由meta 设置导航隐藏与显示功能的示例代码
2020/09/04 Javascript
Python使用gensim计算文档相似性
2016/04/10 Python
浅析Python数据处理
2018/05/02 Python
完美解决pyinstaller打包报错找不到依赖pypiwin32或pywin32-ctypes的错误
2020/04/01 Python
HTML5表单验证特性(知识点小结)
2020/03/10 HTML / CSS
全球第二大家装零售商:Lowe’s
2018/01/13 全球购物
泰坦健身器材:Titan Fitness
2018/02/13 全球购物
德国购买门票网站:ADticket.de
2019/10/31 全球购物
Gibson London官网:以地道的英国男装而著称
2019/12/06 全球购物
母亲追悼会答谢词
2014/01/27 职场文书
入党积极分子自我鉴定范文
2014/03/25 职场文书
建筑工程技术专业求职信
2014/07/16 职场文书
春节超市活动方案
2014/08/14 职场文书
2014年财务工作自我评价
2014/09/23 职场文书
习近平在党的群众路线教育实践活动总结大会上的讲话
2014/10/21 职场文书
盲山观后感
2015/06/11 职场文书
修辞手法有哪些?
2019/08/29 职场文书