python+request+pymysql+pytest数据驱动
一.pymysql简单使用
1.安装mysql
下载地址:https://www.mysql.com/,安装教程这里不做介绍了,网上一大推。
2.安装pymysql库
在Terminal终端输入:pip install pymysql
3.pymysql操作数据库
1)导入pymysql库,创建数据库连接
conn = pymysql.connect(host="127.0.0.1", # 本地服务ip
user="root", # 用户名
password="root", # 密码
database="pymysql", # 库
port=3306, # 端口号
autocommit=False, # 是否自动提交
charset="utf8") # 设置utf编码
2)创建游标
execute()执行sql语句
cur = conn.cursor() # 创建游标
sql = "create table student(id int(10),name varchar(10))"
cur.execute(sql) # 执行sql,执行后返回的是影响的条数
创建游标执行sql语句后fetchall()默认返回元组类型的数据,我们要想让其返回dict类型的,可加入相应参数
cur = conn.cursor(pymysql.cursors.DictCursor)
executemany()执行sql语句
a_list = [(1, "李明"), (2, "李祥")]
sql = "insert into student (id,name ) values (%s,%s)" # %s占位符,通用的
cur_list = cur.executemany(sql, a_list) # 批量执行sql
executemany(self, query, args):为执行批量语句时使用的,query为执行的sql语句,args为传入的数据,列表中嵌套元组类型。
execute()也可批量执行语句,只是执行效率没executemany()快,因此执行单条语句时推荐使用execte(),批量时推荐使用exectemany()。
3)返回查询数据的操作
cur.fetchone() : 返回查询第一条的结果集
cur.fetchall() : 返回所有的查询结果集,元组类型
cur.fetchmany(): 默认返回第一条结果集,可手动在括号中填写返回条数
cur.rowcount:返回影响的条数。注意这里是属性,不是方法
4)commit的使用
我们在操作数据库时,进行增删改后需求提交,否则的话数据库对应的数据是不会发生变化的
conn.commit()
若的创建数据库连接的时候autocommit设置为True,自动提交后。此步骤可省略
5)执行完毕后,关闭游标和数据库连接
cur.close()
conn.close()
二.数据驱动
1)我们以获取企业微信token为例,首先先从数据库获取相应的数据

def pymysql_01():
# 创建数据库连接
conn = pymysql.connect(host="127.0.0.1", # 本地服务ip
user="root", # 用户名
password="root", # 密码
database="li", # 库
port=3306, # 端口号
autocommit=False, # 是否自动提交
charset="utf8") # 设置utf编码
cur = conn.cursor(pymysql.cursors.DictCursor) # 创建游标 pymysql.cursors.DictCursor为查询时返回dict类型
sql = "select * from pymysql"
cur.execute(sql)
list_id = []
for i in cur.fetchall():
list_id.append(i)
cur.close()
conn.close()
return list_id
2)@pytest.mark.parametrize()实现数据驱动
@pytest.mark.parametrize("param", pymysql_01())
def test_weixin(param):
url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken"
data = requests.get(url, params=param)
assert data.json()["errcode"] == 0
3)运行结果当然也是完美的

文章来源:https://www.cnblogs.com/lihongtaoya/ ,请勿转载
python+request+pymysql+pytest数据驱动的更多相关文章
- python+request接口自动化框架
python+request接口自动化框架搭建 1.数据准备2.用python获取Excel文件中测试用例数据3.通过requests测试接口4.根据接口返回的code值和Excel对比 但本章只讲整 ...
- python+request+robot framework接口自动化测试
python+requests实现接口的请求前篇已经介绍,还有不懂或者疑问的可以访问 python+request接口自动化框架 目前我们需要考虑的是如何实现关键字驱动实现接口自动化输出,通过关键字的 ...
- python之pymysql模块学习(待完善...)
pymysql介绍 pymysql是在python3.x版本中用于连接mysql服务器的一个库.python2中则使用mysqldb. 安装方法: pip install pymysql 使用实例: ...
- python request
python request a. 客户端向服务端发送多层字典的值 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 obj = ...
- python的pymysql模块简介
一.介绍 在python中用pymysql模块来对mysql进行操作,该模块本质就是一个套接字客户端软件,使用前需要事先安装 pip3 install pymysql 二.操作简介 import py ...
- python中pymysql使用
python中pymysql使用 https://blog.csdn.net/johline/article/details/69549131 import pymysql # 连接数据库 conne ...
- python request接口测试笔记(1)
python request接口测试笔记(1) 涉及到的功能说明: 需要登录拿到token,才能进行下一个接口的请求 读取csv文件中的信息,作为接口的参数 将接口响应结果,写入csv文件,以便分析统 ...
- Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁
Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁 一丶安装 pip install PyMySQL 二丶pymysql连接数据库 ### 语法: ...
- Python进阶----pymysql模块的使用,单表查询
Python进阶----pymysql模块的使用,单表查询 一丶使用pymysql 1.下载pymysql包: pip3 install pymysql 2.编写代码 ...
随机推荐
- iOS中 Tagged Pointer 技术
前言: 从64位开始,iOS引入了Tagged Pointer技术,用于优化NSNumber.NSDate.NSString等小对象的存储. Tagged Pointer主要为了解决两个问题: 内 ...
- 搭建一个完整的K8S集群-------基于CentOS 8系统
创建三个centos节点: 192.168.5.141 k8s-master 192.168.5.142 k8s-nnode1 192.168.5.143 k8s-nnode2 查看centos系统版 ...
- csdn 不可复制代码的解决方法
简介 由于csdn需要登陆才可以复制,需要脚本才可以操作 脚本 直接在console控制台输入以下代码即可直接复制 $("#content_views pre").css(&quo ...
- 论文解读(GSAT)《Interpretable and Generalizable Graph Learning via Stochastic Attention Mechanism》
论文信息 论文标题:Interpretable and Generalizable Graph Learning via Stochastic Attention Mechanism论文作者:Siqi ...
- LitJson报错记录
1.float转double报错 报错类型: Max allowed object depth reached while trying to export from type System.Coll ...
- Flutter-填平菜鸟和高手之间的沟壑
Flutter-填平菜鸟和高手之间的沟壑 准备写作中... 1.Flutter-skia-影像,Flutter skia-图形渲染层.应用渲染层2.方法通道使用示例,用于演示如何使用方法通道实现与原生 ...
- Vnc自动登录器-多国语言绿色版
推荐:介绍一个VNC连接工具:iis7服务器管理工具.IIs7服务器管理工具可以批量连接并管理VNC服务器.作为服务器集成管理器,它最优秀的功能就是批量管理windows与linux系统服务器.vps ...
- 百亿数据百亿花, 库若恒河沙复沙,Go lang1.18入门精炼教程,由白丁入鸿儒,Go lang数据库操作实践EP12
Golang可以通过Gorm包来操作数据库,所谓ORM,即Object Relational Mapping(数据关系映射),说白了就是通过模式化的语法来操作数据库的行对象或者表对象,对比相对灵活繁复 ...
- 从HashMap的执行流程开始 揭开HashMap底层实现
心得:如何学习源码: 从某个执行过程入手,建议先从整体入手,了解底层的数据结构是怎么一步一步优化的.最后,在了解完底层的数据结构优化过程后,从重要的核心方法入手,从它的执行流程入手,先去网上搜索了解它 ...
- KingbaseES R3 集群pcp_attach_node 更新show pool_nodes中节点状态
系统环境: 操作系统: [kingbase@node2 bin]$ cat /etc/centos-release CentOS Linux release 7.2.1511 (Core) 数据库: ...