在线客服
扫描二维码
下载博学谷APP扫描二维码
关注博学谷微信公众号
MySQL 是目前最为流行的关系型数据库。接下来我们通过一个简单的案例,练习如何使用 PyMySQL 模块进行增删改查的操作。简单来讲,核心步骤有两步:链接数据库,读取 CSV 文件并导入数据表,然后查询数据,将数据表和计算结果导出为 CSV 文件。下面一起来具体看看吧~
Step1: 安装 PyMySQL 模块
在正式动手之前,我们需要先安装 PyMySQL 模块。
(1)使用 pip 安装, 清华镜像:
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple pymysql
(2)使用 conda 安装
conda install pymysql
Step2: 从 CSV 文件导入数据到 MySQL 数据表
安装好以后,我们来进行第二步操作,从 CSV 文件导入数据到 MySQL 数据表。与内置的 SQLite 模块一样, PyMySQL 也遵循 DB-API 规范,因此我们前面开发的大多数代码经过简单修改即可使用,以下代码中主要注释了与 SQLite 操作的不同之处。
# 导入 pymysql 模块
import pymysql
# 连接数据库, 这里需要提供许多参数给 connect 方法
# host 服务器ip地址
# user 用户名 password 密码
# db 数据库名称
cn = pymysql.connect(host='localhost', user='pandas', password='pandas', db='pandas')
# port 端口 缺省值为 3306
# 新建游标对象 :和 SQLite 一样
cur = cn.cursor()
# 建表SQL语句, 小技巧: if not exists 不会引起表已经存在的错误
# MySQL 使用的是 auto_increment , 注意有个下划线
artist_create_table = """
create table if not exists artist(
id integer primary key auto_increment not null,
name varchar(255)
)
"""
try:
cur.execute(artist_create_table)
print(" 成功建表 ")
except:
pass
# 插入语句 , 使用 %(id)s 意味着我们会用字典对象替换数据
# PyMYSQL 使用的语法是 %(名称)s
artist_insert ="""
insert into artist(id, name) values ( %(id)s, %(name)s )
"""
# 以下代码和 SQLite 一样
# 导入 csv 模块
import csv
# 用 with 语法, 打开文件
with open('artist.csv', newline='') as csvfile:
# 用 DictReader 类, 方便开发
reader = csv.DictReader(csvfile)
# 按行遍历csv 文件
for row in reader:
try:
# 按行执行 SQL 语句, 注意, 这里使用 字符串的format方法将数据替换进去
# 如果可以相信数据的安全性可以这样做, 如果数据来自互联网, 需要用另一种更加安全的方式
cur.execute(artist_insert, {"id": row['id'], "name": row['name'] } )
except Exception as e:
print(e)
print(" 成功导入 CSV 数据" )
# 提交事务
cn.commit()
# 关闭数据库
cn.close()
Step3: 将数据表与计算结果导出为 CSV 文件
接下来我们使用 execute 方法获取数据,然后输出到 CSV 文件,与 SQLite 代码类似:
# 导入 pymysql 模块
import pymysql
# 连接数据库
cn = pymysql.connect(host='localhost', user='pandas', password='pandas', db='pandas')
# 新建游标对象
cur = cn.cursor()
# 用 with语法打开文件
with open("artist_data.csv", 'w') as csvfile:
# 首先读取 description 写入 CSV 的第一行
# 执行 SQL 语句
results= cur.execute("select * from artist")
# 获得 description
description = cur.description
# 新建 CSV writer 对象
writer = csv.writer(csvfile)
# 写入列名称
writer.writerow([ x[0] for x in description ] )
# 遍历数据
for row in cur:
# 写入每一行数据
writer.writerow(row)
print(" 成功写入 CSV 文件")
以上我们使用 PyMySQL 模块为例,介绍了如何使用 Python 对 MySQL 数据库进行增删改查,大家都学会了吗?
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
Python为什么这么火?编程零基础该如何学习Python?
Python为什么这么火?编程零基础该如何学习Python?其实Python的火爆不是偶然,时代的潮流驱动也好,自身的语言优势也好,对于零基础的学习者来说,学习Python都是最好的选择。至于Python学习方式有很多,看书、报培训班都是比较靠谱的,看大家适应哪种学习模式。
5145
2019-11-20 13:21:14
如何利用Python批量下载百度图片?
有时候大家需要保存下载百度图片,但是在数量很大的情况下,一张一张地下载就显得很繁琐麻烦。那么,有没有一种方法可以把搜索到大量的百度图片直接下载到本地电脑中呢?当然有,答案就是利用Python。下面我们主要从方案思路和代码演示两个方面,来看看如何利用Python批量下载百度图片。
5941
2020-04-20 10:22:36
Python零基础入学课程学什么?
如果你没有具备任何一门语言的面向对象知识,是完完全全的编程小白,那么博学谷的Python零基础入学课程将带你快速上手Python的基础入门知识。学习该套入学课程,你将掌握 Python入门语法所需要的一切知识点,为将来的深入学习Python打下坚实的基础。下面我们来看看Python零基础入学课程的具体学习内容。
4332
2020-06-22 18:42:35
自学Python需要多长时间从入门到精通?
Python是全球前3大最流行的编程语言之一,以其简洁优美、功能强大、高效率的先天优势成为企业新宠此外,国内计算机教育也越来越重视Python在编程中的地位。Python非常适合零基础的同学学习,比较简单没有指针变量类型等复杂的概念。
4943
2021-01-26 10:39:22
连接查询自连接的SQL语句怎么写?
连接查询自连接的SQL语句怎么写?自连接查询左表和右表是同一个表,根据连接查询条件查询两个表中的数据。学习自连接要能够写出自连接查询的SQL语句。
5077
2022-01-19 11:53:11
热门文章
- 前端是什么
- 前端开发的工作职责
- 前端开发需要会什么?先掌握这三大核心关键技术
- 前端开发的工作方向有哪些?
- 简历加分-4步写出HR想要的简历
- 程序员如何突击面试?两大招带你拿下面试官
- 程序员面试技巧
- 架构师的厉害之处竟然是这……
- 架构师书籍推荐
- 懂了这些,才能成为架构师 查看更多
扫描二维码,了解更多信息