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.编写代码 ...
随机推荐
- CF1700C Helping the Nature
题目大意: 给出一个长度为 n 的序列 a,每次可以进行三种操作中的一种: 选择i,将 a_1,a_2,...,a_i减1. 选择i,将 a_i,a_i+1,...,a_n减1. 将所有 a_i加1. ...
- PHP小知识收集
PEAR 是"PHP Extension and Application Repository"的缩写,即PHP扩展和应用仓库. PECL 是"PHP Extension ...
- MySQL为什么"错误"选择代价更大的索引
欢迎来到 GreatSQL社区分享的MySQL技术文章,如有疑问或想学习的内容,可以在下方评论区留言,看到后会进行解答 MySQL优化器索引选择迷思. 高鹏(八怪)对本文亦有贡献. 1. 问题描述 群 ...
- 官宣!DolphinScheduler 毕业成为 Apache 软件基金会顶级项目
全球最大的开源软件基金会 Apache 软件基金会(以下简称 Apache)于北京时间 2021年4月9日在官方渠道宣布Apache DolphinScheduler 毕业成为Apache顶级项目.这 ...
- 从零开始Blazor Server(11)--编辑用户
用户编辑和角色编辑几乎一模一样,这里先直接贴代码. @page "/user" @using BlazorLearn.Entity @using Furion.DataEncryp ...
- 我写的蓝宝石留言本php版 v4.5
蓝宝石留言本php版v4.5采用原生php编写,在php5.6~php7.x下调试通过.本留言本使用了utf-8编码. include/config1.php是数据库连接参数的配置文件, includ ...
- 3-14 Python处理XML文件
xml文件处理 什么是xml文件? xml即可扩展标记语言,它可以用来标记数据.定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言. 从结构上,很像HTML超文本标记语言.但他们被设计的目的 ...
- Java循环解析
Java循环解析 while循环(先判断) int i=0; while (i<100){ i++; System.out.println(i); } DoWhile循环(先执行,后 ...
- Codeforces Round #604 (Div. 2) -D
Problem - D - Codeforces 题意 : 有 a 个0,b个1,c个2,d个3,构成一个序列,使得每两个数字之间的差值为1 题解: 就是以四种数字分别为起点,暴力模拟 #includ ...
- 02_Linux基础-文件系统层次结构-提示符-进程-命令格式-隐藏文件-通配符-绝对相对路径-{1..100}-ls-mkdir-其他基础命令
02_Linux基础-ls-mkdir-cd-pwd-man-useradd-su-rm-tree-tab-passwd-w-ssh-touch-date-stat-cp-mv-du-文件系统层次结构 ...