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

作者:mrr 时间:2022-08-20 12:48:57 

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倍,网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

来源:http://developer.51cto.com/art/201906/597417.htm

标签:python,自动化,数据驱动
0
投稿

猜你喜欢

  • 微信小程序 支付功能实现PHP实例详解

    2023-11-19 08:53:36
  • 三分钟教会你用Python+OpenCV批量裁剪xml格式标注的图片

    2023-07-09 14:11:01
  • Python3.5运算符操作实例详解

    2021-06-09 11:41:17
  • 详解vue页面首次加载缓慢原因及解决方案

    2024-05-25 15:19:45
  • 在Python中字符串、列表、元组、字典之间的相互转换

    2021-08-30 07:09:42
  • 一道求$b相对于$a的相对路径的php代码

    2023-07-12 05:37:46
  • django中forms组件的使用与注意

    2021-03-11 00:14:04
  • Python使用pickle模块储存对象操作示例

    2021-05-17 00:29:49
  • javascript json字符串到json对象转义问题

    2023-07-02 05:18:22
  • Python设计模式之抽象工厂模式

    2021-02-06 09:18:59
  • PHP开启opcache提升代码性能

    2023-06-17 04:39:55
  • 查看vue-cli脚手架的版本号和vue真实版本号及详细操作命令

    2023-07-02 17:04:20
  • asp随机提取access数据库记录的几种方法

    2007-09-06 19:42:00
  • Python Counting Bloom Filter原理与实现详细介绍

    2021-04-04 19:01:54
  • python中if和elif的区别介绍

    2022-07-23 14:22:10
  • Vue从TodoList中学父子组件通信

    2024-05-29 22:22:20
  • golang 语言中错误处理机制

    2024-04-25 13:21:39
  • golang高并发的深入理解

    2023-06-19 09:12:01
  • 如何在 IE 中使用 HTML5 元素

    2009-06-14 19:44:00
  • python tkinter实现学生信息管理系统

    2021-11-01 18:46:16
  • asp之家 网络编程 m.aspxhome.com