网站首页 > 技术文章 正文
早就步入大数据时代,人们对“数据库”这个词都是耳熟能详。但是,很多人印象中认为数据库的门槛比较高,需要架设专用的服务器设备才能使用,所以望而却步。
其实没有服务器,我们照样能使用数据库。像我们每天使用的微信,它的个人聊天记录就存储在我们手机上的数据库里面。
这个数据库就是SQLite,我们只要使用Python就能轻松这个数据库:
SQLite数据库简介
SQLite是一个轻量级的关系型数据库管理系统,它不需要单独的服务器进程或配置,而是作为一个库与应用程序集成。SQLite支持SQL语言进行数据存储和查询,并且提供事务管理、ACID属性等关键功能。由于其体积小、性能高、易于使用,广泛应用于移动应用、桌面软件和嵌入式系统中。
如何使用Python操作SQLite
安装Python的时候,系统已经自动安装了SQLite,所以不需要我们另外安装。(Python的安装非常简单,可以参见《Python入门-Python的下载和安装》)
- 使用Python创建、连接和关闭数据库
import sqlite3
# 连接到SQLite数据库
# 如果数据库不存在,它将被创建
# 如果数据库已存在,它将被打开
conn = sqlite3.connect('d:\\sqlite\\test1.db')
# 关闭数据库连接
conn.close()
运行上述代码,D:\SQLite目录下出现test1.db文件,这个就是数据库文件。
- 使用Python执行SQL语句
非常简单,只要创建一个游标对象,就可以通过它的execute方法执行SQL语句,执行结束需要调用commit方法提交事务。
# 创建游标对象
cursor = conn.cursor()
# 创建数据表
cursor.execute('''
CREATE TABLE IF NOT EXISTS users (
id INTEGER PRIMARY KEY,
name TEXT NOT NULL,
age INTEGER
)
''')
# 提交事务
conn.commit()
数据的增删改都可通过execute方法实现
# 插入数据
cursor.execute("INSERT INTO users (name, age) VALUES (?, ?)", ('Alice', 30))
cursor.execute("INSERT INTO users (name, age) VALUES (?, ?)", ('Bob', 25))
# 提交事务
conn.commit()
数据的查询也是同样,可以通过游标的fetchall方法将结果集取出。
# 查询数据
cursor.execute("SELECT * FROM users")
rows = cursor.fetchall()
for row in rows:
print(row)
与Pandas联合使用更为有效
1、场景一:使用Pandas读取文件数据存入SQLite
import sqlite3
import pandas as pd
# 使用with语句作为上下文管理器
with sqlite3.connect('d:\\sqlite\\test1.db') as conn:
# 将Excel文件数据加载到DataFrame中
df =pd.read_excel('d:\\data.xlsx')
# 将DataFrame写入SQLite数据库
df.to_sql('new_users', conn, if_exists='replace', index=False)
# 连接在with语句块结束时自动关
2、场景二:使用Pandas读取SQLite数据集写入文件
import sqlite3
import pandas as pd
# 使用with语句作为上下文管理器
with sqlite3.connect('d:\\sqlite\\test1.db') as conn:
# 执行SQL查询并将结果加载到DataFrame中
df = pd.read_sql_query("SELECT * FROM users", conn)
# 将DataFrame写入Excel文件中
df.to_excel('d:\\data.xlsx', index=False)
# 连接在with语句块结束时自动关闭
结语
通过上面的演示可以看出,使用Python进行数据库操作非常简单,特别是和Pandas结合起来使用,既可以发挥数据库SQL语言的优势,又可以发挥Pandas读写数据的长处,绝对可以大大提升我们的工作效率。
猜你喜欢
- 2025-01-01 Python的一个轻量级桌面GUI开发第三方库:Eel
- 2025-01-01 隐藏彩蛋:你知道python有一个内置的数据库吗?
- 2025-01-01 Python编程绝对初学者指南,一步一步的指南,有示例和实验练习
- 2025-01-01 python服务器socket编程
- 2025-01-01 「大数据」Hana入门
- 2025-01-01 搭建Python自带静态Web服务器
- 2025-01-01 python套接字socket编程搭建简易服务器,完成计算器实例
- 2025-01-01 Python快速搭建HTTP服务
- 2025-01-01 手把手教你使用Python轻松搞定发邮件
- 2025-01-01 软件测试工程师必会技术:Python带你上手WebSocket
- 02-21走进git时代, 你该怎么玩?_gits
- 02-21GitHub是什么?它可不仅仅是云中的Git版本控制器
- 02-21Git常用操作总结_git基本用法
- 02-21为什么互联网巨头使用Git而放弃SVN?(含核心命令与原理)
- 02-21Git 高级用法,喜欢就拿去用_git基本用法
- 02-21Git常用命令和Git团队使用规范指南
- 02-21总结几个常用的Git命令的使用方法
- 02-21Git工作原理和常用指令_git原理详解
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)