基于Python的Web自动化(Selenium)之读取文件

简单介绍

关于数据驱动的形式有很多,我们既可以通过定义变量的方式进行参数化,也可以通过定义数组、字典方式进行参数化,还可以通过读取文件(txt\csv\xml)的方式进行参数化。下面简单介绍下如何读取txt和csv格式,xml在测试过程中好像用的少(可能是我的测试还不够丰富,等有时间也介绍下xml的读取方式)。

实际操作

一、读取txt格式

关于txt格式文件读取,这里不再赘述,可以参考Python三种读取文件方式这篇文章。着重强调一下格式。注意,我们在存储数据的时候为了方便后续读取需要的数据就必须使用特殊的一个符号区分每个不同数据的意义。比如我们需要对“username”和“password”两个字段进行测试,我们就需要在txt文件中构造关于这两个字段的数据。

 
构造数据

这里创建了三组测试数据,都是用“,”隔开,然后我们根据读取到的数据使用“split”方法根据“,”进行分隔数据,然后再取数据存入变量中使用。当然这个特殊符号根据自己喜好自定,当然使用一下方便好记的符号最好。

二、读取csv格式

如果现在需要测试一组数据包括用户名、年龄、性别、邮箱等信息,此时再使用txt显得有点不方便了。我们可以使用通过创建csv格式文件,读取方式使用csv模块的reader()方法读取,然后通过for循环遍历文件中的数据。

 
csv文件

1、遍历每一行数据

代码:

# -*- coding: utf-8 -*-

'''

@author: April_Chou

@time: 2018/4/16 20:54

'''

import csv

user_file = csv.reader(open('D:/WorkSpace2/seleniumTest/4/info.csv','r'))

扫描二维码关注公众号,回复: 26427 查看本文章

for linein user_file:

    print(line)

结果:

['姓名', '年龄', '学号']

['Python', '3', '1']

['Java', '4', '2']

['Ruby', '5', '3']

2、获取某一列数据

代码:

# -*- coding: utf-8 -*-

'''

@author: April_Chou

@time: 2018/4/16 20:54

'''

import csv

user_file = csv.reader(open('D:/WorkSpace2/seleniumTest/4/info.csv','r'))

for linein user_file:

    print(line[0])

结果:

姓名

Python

Java

Ruby

三、读取xml格式

有时候读取的数据格式是不规则的,比如在配置一个xml文件配置自动化脚本的URL、浏览器、登陆用户名和密码等,这时候就需要读取xml文件。首先导入xml的minidom模块,用来处理XML文件,然后使用parse()方法打开一个XML文件,documentElement用于得到XML文件的唯一根元素。

猜你喜欢

转载自www.cnblogs.com/April-Chou-HelloWorld/p/8858562.html