python读取csv文件完成接口测试参数化

导入pandas包

读取csv文件示例: getcsv.py

import pandas
import json

# 读取csv文件名
# 定义csv文件的路径和文件名
csv_path = "csv.csv"
# sep参数指定csv文件的分隔符,默认值是逗号,如果是制表符,该值为:\t
datacsv = pandas.read_csv(csv_path, sep=',')
print("csv数据是:", datacsv)
# csv数据转换为json数据.self指定要转换的csv数据,orient是固定写法,要转为json格式,该值为:records
datajson = pandas.DataFrame.to_json(self=datacsv, orient="records")
print("json数据是:", datajson)
# json数据转换为list
datalist = json.loads(datajson)
print("list数据是:", datalist)

post请求导入csv示例:

import unittest
import ddt
import requests
from data import getcsv

# 获取参数化的数据
list01 = getcsv.datalist

@ddt.ddt()
class Dep01(unittest.TestCase):
    @ddt.data(*list01)
    # 将遍历取得list01列表中的每个元素,list01中有几个元素,Dep01将循环几次
    def test01(self,dptinfo):
        dptid = dptinfo["dep_id"]
        dptname = dptinfo["dep_name"]
        mastername = dptinfo["master_name"]
        slogan = dptinfo["slogan"]
        # 定义地址
        url = "http://127.0.0.1:8000/api/departments/"
        data = '{"data":[{"dep_id":"%s","dep_name":"%s","master_name":"%s","slogan":"%s"}]}' % (dptid, dptname, mastername, slogan)

        print("拼接的消息体数据为:", data)
        # 定制头部字段
        myheader = {"Content-Type": "application/json"}
        # 发送请求
        res = requests.post(url=url, data=data.encode("utf-8"), headers=myheader)
        print("获取到的新增响应报文为:", res.text)
        # 获取实际代码
        code_act = res.status_code
        # 获取预期代码
        code_expect = dptinfo["code"]
        # 比较
        self.assertEqual(str(code_act), str(code_expect))


if __name__ == '__main__':
    unittest.main()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值