一.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数据驱动的更多相关文章

  1. python+request接口自动化框架

    python+request接口自动化框架搭建 1.数据准备2.用python获取Excel文件中测试用例数据3.通过requests测试接口4.根据接口返回的code值和Excel对比 但本章只讲整 ...

  2. python+request+robot framework接口自动化测试

    python+requests实现接口的请求前篇已经介绍,还有不懂或者疑问的可以访问 python+request接口自动化框架 目前我们需要考虑的是如何实现关键字驱动实现接口自动化输出,通过关键字的 ...

  3. python之pymysql模块学习(待完善...)

    pymysql介绍 pymysql是在python3.x版本中用于连接mysql服务器的一个库.python2中则使用mysqldb. 安装方法: pip install pymysql 使用实例: ...

  4. 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 =  ...

  5. python的pymysql模块简介

    一.介绍 在python中用pymysql模块来对mysql进行操作,该模块本质就是一个套接字客户端软件,使用前需要事先安装 pip3 install pymysql 二.操作简介 import py ...

  6. python中pymysql使用

    python中pymysql使用 https://blog.csdn.net/johline/article/details/69549131 import pymysql # 连接数据库 conne ...

  7. python request接口测试笔记(1)

    python request接口测试笔记(1) 涉及到的功能说明: 需要登录拿到token,才能进行下一个接口的请求 读取csv文件中的信息,作为接口的参数 将接口响应结果,写入csv文件,以便分析统 ...

  8. Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁

    Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁 一丶安装 pip install PyMySQL 二丶pymysql连接数据库 ### 语法: ...

  9. Python进阶----pymysql模块的使用,单表查询

    Python进阶----pymysql模块的使用,单表查询 一丶使用pymysql ​   ​   1.下载pymysql包: pip3 install pymysql ​​   ​   2.编写代码 ...

随机推荐

  1. 【高并发】通过源码深度分析线程池中Worker线程的执行流程

    大家好,我是冰河~~ 在<高并发之--通过ThreadPoolExecutor类的源码深度解析线程池执行任务的核心流程>一文中我们深度分析了线程池执行任务的核心流程,在ThreadPool ...

  2. 栈Stack

  3. Luogu2251 质量检测 (ST表)

    我怎么开始划水了... #include <iostream> #include <cstdio> #include <cstring> #include < ...

  4. RocketMQ保姆级教程

    大家好,我是三友~~ 上周花了一点时间从头到尾.从无到有地搭建了一套RocketMQ的环境,觉得还挺easy的,所以就写篇文章分享给大家. 整篇文章可以大致分为三个部分,第一部分属于一些核心概念和工作 ...

  5. java-Servlet-cookie and session

    1 状态管理 a) 什么是状态管理?将浏览器与web服务器之间多次交互当做一个整体处理,并且将多次交互涉及的数据(即状态)保存下来. b) 如何进行状态管理? 可以将状态保存在客户端将状态保存到浏览器 ...

  6. 七分钟学会 HTML 网页制作

    什么是HTML 点击打开视频讲解更加详细 Hyper Text Markup Language(超文本标记语言) 标签控制排版 体积小,方便传输 编写HTLML 推荐使用:VS Code <!D ...

  7. Java Stream 函数式接口外部实例的引用

    Java Function Interface 函数式接口: Stream.empty() .filter(Predicate) .map(Function) .forEach(Consumer); ...

  8. WAF对抗-安全狗(联合查询篇)

    WAF对抗-安全狗(联合查询篇) 实验环境 网站安全狗APACHE版V4.0.靶场:dvwa 为了方便对比可以在这个在线靶场申请一个dvwa https://www.vsplate.com/ mysq ...

  9. python使用pickle序列化对象读取输出二进制文件

    import pickle class tick: name = '牛牛牛' age = 10 samp = [1,2,3,'aaa',[12,3],tick()] with open('te.xxx ...

  10. HMS Core基于地理位置请求广告,流量变现快人一步

    对于想买车的用户来说,如果走在路上刷社交软件时突然在App里收到一条广告:"前方500米商圈里的某品牌汽车正在做优惠,力度大福利多."不管买不买,八成都会去看看,原因有三:距离近. ...