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实现八大排序算法
Aug 13 Python
python3使用scrapy生成csv文件代码示例
Dec 28 Python
Python及Django框架生成二维码的方法分析
Jan 31 Python
对Python中plt的画图函数详解
Nov 07 Python
Python2与Python3的区别实例总结
Apr 17 Python
python或C++读取指定文件夹下的所有图片
Aug 31 Python
Python 元组操作总结
Sep 18 Python
Python netmiko模块的使用
Feb 14 Python
Python Flask框架实现简单加法工具过程解析
Jun 03 Python
浅谈Keras参数 input_shape、input_dim和input_length用法
Jun 29 Python
Python 防止死锁的方法
Jul 29 Python
Django分页器的用法你都了解吗
May 26 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
PHP新手上路(四)
2006/10/09 PHP
php数组添加与删除单元的常用函数实例分析
2015/02/16 PHP
PHPCMS忘记后台密码的解决办法
2016/10/30 PHP
PHP在同一域名下两个不同的项目做独立登录机制详解
2017/09/22 PHP
Laravel 实现密码重置功能
2018/02/23 PHP
Windows Live的@live.com域名注册漏洞 利用代码
2006/12/27 Javascript
JS 无法通过W3C验证的处理方法
2010/03/09 Javascript
javascript的内存管理详解
2013/08/07 Javascript
JS获得浏览器版本和操作系统版本的例子
2014/05/13 Javascript
jQuery中end()方法用法实例
2015/01/08 Javascript
[原创]JavaScript语法高亮插件highlight.js用法详解【附highlight.js本站下载】
2016/11/01 Javascript
从零学习node.js之文件操作(三)
2017/02/21 Javascript
详解angularjs获取元素以及angular.element()用法
2017/07/25 Javascript
在页面中引入js的两种方法(推荐)
2017/08/29 Javascript
Vue2.0用户权限控制解决方案的示例
2018/02/10 Javascript
JSONP原理及应用实例详解
2018/09/13 Javascript
js中的数组对象排序分析
2018/12/11 Javascript
JS中数据结构与算法---排序算法(Sort Algorithm)实例详解
2019/06/17 Javascript
微信小程序如何调用json数据接口并解析
2019/06/29 Javascript
快速解决layui弹窗按enter键不停弹窗的问题
2019/09/18 Javascript
微信小程序实现锚点跳转
2020/11/23 Javascript
在Python中使用成员运算符的示例
2015/05/13 Python
python实现批量修改图片格式和尺寸
2018/06/07 Python
Python之修改图片像素值的方法
2019/07/03 Python
Python 实现大整数乘法算法的示例代码
2019/09/17 Python
Python turtle库绘制菱形的3种方式小结
2019/11/23 Python
python脚本后台执行方式
2019/12/21 Python
Python+opencv+pyaudio实现带声音屏幕录制
2019/12/23 Python
python 在threading中如何处理主进程和子线程的关系
2020/04/25 Python
OpenCV 之按位运算举例解析
2020/06/19 Python
HTML5实现Notification API桌面通知功能
2016/03/02 HTML / CSS
美国高级工作服品牌:Carhartt
2018/01/25 全球购物
应届生的求职推荐信范文
2013/11/30 职场文书
个人学习群众路线心得体会
2014/11/05 职场文书
张思德观后感
2015/06/09 职场文书
新娘婚礼致辞
2015/07/27 职场文书