侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

python+jinja2实现接口数据批量生成工具

Python  /  管理员 发布于 8年前   200

在做接口测试的时候,我们经常会遇到一种情况就是要对接口的参数进行各种可能的校验,手动修改很麻烦,尤其是那些接口参数有几十个甚至更多的,有没有一种方法可以批量的对指定参数做生成处理呢。

答案是肯定的!

python的jinja2模板库可以很好的满足我们的需求,通过维护一个原始数据模板,将我们想要动态生成的变量模板化,就可以实现需求。

现在我们有这样的一个请求数据

{ "abc":"123", "p2p":"123", "smid":"20180807220733939b66d80092eea34ce9e77f30bedff12345b7d5a3faa11b", "test":{  "test1":"1",  "test2":"2" }, "test3":"3"}

如果想对其中的smid字段进行批量修改并生成新的请求数据就可以进行如下操作:

1、首先新建一个名为fp_template.txt的文本文件;

2、将上面的接口请求数据复制粘贴进这个txt文件中,我们以此作为“模板文件”;

3、新建一个predata文件夹用来存放生成后的数据文件;

4、对smid字段进行模板化(模板格式可以参考jinja2的语法,这里不做赘述),于是上面的请求参数就变成了下面这样:

{ "abc":"123", "p2p":"123", "smid":"{{ smid }}", "test":{  "test1":"1",  "test2":"2" }, "test3":"3"}

实现代码代码如下:

# -*- coding: UTF-8 -*-from jinja2 import Environment,FileSystemLoaderimport osclass DataTemplateFaker: def __init__(self):  self.aesPath = os.getcwd()#获取启动路径  self.resultPath = self.aesPath + "/predata/"#指定用来保存生成数据的路径  self.templateFile = "fp_template.txt" #修改我们要批量生成smid的格式 def init_smid(self,start,end):  smidArg = [x for x in range(start, end)]  re = []  for n in smidArg:   re.append("20180807220733939b66d80092eea34ce9e77f30bedff" + str(n) + "b7d5a3faa11b")  return re #操作模板文件 def preContent(self,arg):  env = Environment(loader=FileSystemLoader('./'))  tpl = env.get_template(self.templateFile)  renderContent = tpl.render(smid=arg)  return renderContent #通过修改的smid列表批量替换模板文件并写入指定文件中 def makeContent(self,preList):  x = 0  for i in preList:   x = x + 1   filename = str(self.resultPath) + 'data_' + str(x) + '.txt' #用以区分存放新生成的请求数据(也可以写到一个文件中)   renderContent = self.preContent(i)   with open(filename, 'w') as f:    f.writelines(renderContent)    f.close()if __name__ == "__main__": AT = DataTemplateFaker() reList = AT.init_smid(1,10)#控制生成数据的范围 AT.makeContent(reList)

运行程序,就能得到新生成的数据

当然,我们也可以对其他的参数进行指定修改,如修改p2p,只需要修改模板文件:

{ "abc":"123", "p2p":"{{ p2p }}", "smid":"20180807220733939b66d80092eea34ce9e77f30bedff12345b7d5a3faa11b", "test":{  "test1":"1",  "test2":"2" }, "test3":"3"}

然后在代码中加入一个方法init_p2p()

# -*- coding: UTF-8 -*-from jinja2 import Environment,FileSystemLoaderimport osclass DataTemplateFaker: def __init__(self):  self.aesPath = os.getcwd()#获取启动路径  self.resultPath = self.aesPath + "/predata/"#指定用来保存生成数据的路径  self.templateFile = "fp_template.txt" #修改我们要批量生成smid的格式 def init_smid(self,start,end):  smidArg = [x for x in range(start, end)]  re = []  for n in smidArg:   re.append("20180807220733939b66d80092eea34ce9e77f30bedff" + str(n) + "b7d5a3faa11b")  return re #修改我们要批量生成p2p的格式  def init_p2p(self,start,end):  p2pArg = [x for x in range(start, end)]  return p2pArg #操作模板文件 def preContent(self,arg):  env = Environment(loader=FileSystemLoader('./'))  tpl = env.get_template(self.templateFile)  renderContent = tpl.render(smid=arg)  return renderContent #通过修改的smid列表批量替换模板文件并写入指定文件中 def makeContent(self,preList):  x = 0  for i in preList:   x = x + 1   filename = str(self.resultPath) + 'data_' + str(x) + '.txt' #用以区分存放新生成的请求数据(也可以写到一个文件中)   renderContent = self.preContent(i)   with open(filename, 'w') as f:    f.writelines(renderContent)    f.close()if __name__ == "__main__": AT = DataTemplateFaker() reList = AT.init_p2p(1,10)#控制生成数据的范围 AT.makeContent(reList)

这只是一个很简单的demo,当然还有很多可优化的地方,比如多字段同时修改、引入faker库进行关联生成伪造数据等,越是复杂且参数繁多的接口越适用,其他的方法就可以天马行空,任君发挥了。

总结

以上所述是小编给大家介绍的python+jinja2实现接口数据批量生成工具,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!


  • 上一条:
    解决Python对齐文本字符串问题
    下一条:
    解决Atom安装Hydrogen无法运行python3的问题
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • AI Agent
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在python语言中Flask框架的学习及简单功能示例(0个评论)
    • 在Python语言中实现GUI全屏倒计时代码示例(0个评论)
    • Python + zipfile库实现zip文件解压自动化脚本示例(0个评论)
    • python爬虫BeautifulSoup快速抓取网站图片(1个评论)
    • vscode 配置 python3开发环境的方法(0个评论)
    • 近期文章
    • OpenAI GPT-5.5正式发布:更会编程和使用计算机的最强模型!(0个评论)
    • opencode AI智能体自主规划开发游戏:王者荣耀模拟战游戏初体验!英雄角色开发中...(0个评论)
    • opencode AI智能体自主规划开发游戏:王者荣耀模拟战游戏初体验!(0个评论)
    • opencode + Oh-my-openagent,我的第一个免费的ai编程智能体管家:Sisyphus(0个评论)
    • Google AI Studio升级全栈 vibe coding体验,可直接构建带登录和数据库的应用(0个评论)
    • Apifox桌面端被曝遭供应链投毒:CDN 脚本被篡改,窃取 SSH 密钥与 Git 凭证(0个评论)
    • 在go语言中实现字符串可逆性压缩及解压缩功能(0个评论)
    • 使用go + gin + jwt + qrcode实现网站生成登录二维码在app中扫码登录功能(0个评论)
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 近期评论
    • test1 在

      opencode + Oh-my-openagent,我的第一个免费的ai编程智能体管家:Sisyphus中评论 test..
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • Zita 在

      Google AI Studio升级全栈 vibe coding体验,可直接构建带登录和数据库的应用中评论 111222..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 2016-10
    • 2016-11
    • 2018-04
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2022-01
    • 2023-07
    • 2023-10
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客