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数据库操作常用功能使用详解(创建表/插入数据/获取数据)
Dec 06 Python
从零学python系列之浅谈pickle模块封装和拆封数据对象的方法
May 23 Python
Python连接mssql数据库编码问题解决方法
Jan 01 Python
Python算法之图的遍历
Nov 16 Python
Python使用matplotlib的pie函数绘制饼状图功能示例
Jan 08 Python
python3实现字符串操作的实例代码
Apr 16 Python
在Pandas中处理NaN值的方法
Jun 25 Python
python实现在函数中修改变量值的方法
Jul 16 Python
Python实现多线程/多进程的TCP服务器
Sep 03 Python
python通过SSH登陆linux并操作的实现
Oct 10 Python
python:目标检测模型预测准确度计算方式(基于IoU)
Jan 18 Python
基于Python3读写INI配置文件过程解析
Jul 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
php中base_convert()进制数字转换函数实例
2014/11/20 PHP
php实现根据词频生成tag云的方法
2015/04/17 PHP
PHP设计模式之注册树模式分析
2018/01/26 PHP
在修改准备发的批量美化select+可修改select时,在非IE下发现了几个问题
2007/01/09 Javascript
js 禁用只读文本框获得焦点时的退格键
2010/04/25 Javascript
jquery全选/全不选/反选另一种实现方法(配合原生js)
2013/04/07 Javascript
javascript利用apply和arguments复用方法
2013/11/25 Javascript
jquery中each方法示例和常用选择器
2014/07/08 Javascript
10个很棒的jQuery代码片段
2015/09/24 Javascript
BootStrap文件上传样式超好看【持续更新】
2016/05/10 Javascript
SeaJS中use函数用法实例分析
2017/10/10 Javascript
vue学习教程之带你一步步详细解析vue-cli
2017/12/26 Javascript
JS计算距当前时间的时间差实例
2017/12/29 Javascript
JS实现Cookie读、写、删除操作工具类示例
2018/08/28 Javascript
Vue extend的基本用法(实例详解)
2019/12/09 Javascript
javascript利用键盘控制小方块的移动
2020/04/20 Javascript
[28:42]Ti4正赛VG vs NEWBEE1
2014/07/19 DOTA
总结python实现父类调用两种方法的不同
2017/01/15 Python
python+matplotlib绘制简单的海豚(顶点和节点的操作)
2018/01/02 Python
Python理解递归的方法总结
2019/01/28 Python
Python----数据预处理代码实例
2019/03/20 Python
PyQt4实时显示文本内容GUI的示例
2019/06/14 Python
python 实现在无序数组中找到中位数方法
2020/03/03 Python
自定义实现 PyQt5 下拉复选框 ComboCheckBox的完整代码
2020/03/30 Python
Python绘制词云图之可视化神器pyecharts的方法
2021/02/23 Python
一些高难度的SQL面试题
2016/11/29 面试题
电话销售经理岗位职责
2013/12/07 职场文书
商场消防管理制度
2014/01/12 职场文书
学生意外伤害赔偿协议书
2014/09/17 职场文书
2014年政风行风评议工作总结
2014/10/21 职场文书
2015年宣传部部长竞选演讲稿
2014/11/28 职场文书
优秀班集体事迹材料
2014/12/25 职场文书
贫困生助学金感谢信
2015/01/21 职场文书
邀请函的格式
2015/01/30 职场文书
高中社区服务活动报告
2015/02/05 职场文书
25句企业管理语录:助你迅速打开思路,句句经典!
2020/01/14 职场文书