收藏!Python内置的轻量级数据库竟如此好用!全网最实用sqlite3实战项目。

前段时间推送了一篇Python操作MySQL数据库的文章:我用 Python 处理3万多条数据,只要几秒钟……,文章发布后反应很好,很多粉丝给我私信,有的朋友说:MySQL安装起来太麻烦了,有没有更简便的方法?

肯定是有的!Python内置的sqlite3模块是一个轻量级的数据库,不需要独立的服务器进程。它的数据库就是一个.db后缀的文件,可以跨平台直接访问,非常便捷。简直就是轻量级数据的首选数据库啊!

今天我们就来用Python实战操作一下sqlite3,通过本案例可以完全掌握sqlite3的常用操作。

本文主要内容:

  • 数据读取和插入:包括原始数据的读取、插入数据库。
  • 数据库操作:包括数据的查询、删除、导出等操作,最后上一个自动化导出的案例。

1. 读取数据并插入数据库

本文以TXT文件为例,进行示范操作。TXT文件为单列数据,以换行符分割,文件数量60+,数据总量5万+。

程序设计思路:自动读取每个TXT文件,再依次读取每一行并插入数据库中。

1.1 源代码

# -*- coding: utf-8 -*-
"""
Created on Fri Jan 17 15:06:42 2020

@author: liulu

源代码已发布到【智能演示】微信公众号,后台回复 sqlite3 可获取下载链接。
"""
import sqlite3    
import os
path = os.getcwd()
files = os.listdir(path)

conn = sqlite3.connect(path+'\db.db') 
cur = conn.cursor()       

cur.execute('create table if not exists numbers (id integer primary key ,number varchar(20) NOT NULL)') 
conn.commit()

i = 0
for file in files:
    if file.split('.')[-1] == 'txt':
        with open(file,'r',encoding = 'UTF-8') as f: 
            next(f)
            for line in f:
                i += 1
                print("插入第", i, "条数据:")
                #print(line)
                cur.execute('insert into numbers values(?,?)',(i,line))
                conn.commit()         
cur.close() 
conn.close() 
print('数据写入完成!共写入',i,' 条数据')

1.2 运行效果

代码运行效果图

1.3 重点代码解释

1)自动获取所有TXT文件名称和路径

了解我的读者都知道,我是比较懒的,我不喜欢指定程序的路径。我写的程序都是自己找路径,自己找文件名称。感兴趣的朋友可以去我的公众号(智能演示)查看这篇文章:获取任意路径下文件名称的2种方法

2)数据库的创建与连接

conn = sqlite3.connect(path+'\db.db')

path是程序所在路径,也是TXT文件的所在路径。这行代码的意思是:如果数据库已经存在,则连接数据库;如果数据库不存在,则先创建数据库,再连接该数据库。

3)创建表

cur.execute('create table if not exists numbers (id integer primary key ,number varchar(20) NOT NULL)')

在数据库db.db 中创建表numbers,表中包含两个字段:id、number。

注意!一定不要忘了conn.commit()保存一下!不然后面的数据是插不进去的。

4)插入数据

①优化打开方式

with open(file,'r',encoding = 'UTF-8') as f:

建议使用 with 语句来打开TXT文件。这样做的好处是,当对象会在with语句结束时会自动关闭。效率更高!不易出错。

②占位符功能

cur.execute('insert into numbers values(?,?)',(i,line))

(?,?) 起到占位符功能,(i,line))中的值会按位置替换到SQL语句中。

这样就实现了数据的自动插入数据库。需要几分钟时间,请耐心等待。


我们查看下db.db文件属性,可以看到存储了51216条数据的数据库文件大小只有1.13MB,可以说是很轻量的。


你可以将这个数据库文件复制到任意一台电脑上,连接上数据库即可进行操作,非常方便。

下面就来说一下sqlite3的常用操作。

2. 数据库操作

2.1 连接数据库

import sqlite3
import os
path = os.getcwd()
files = os.listdir(path)
conn = sqlite3.connect(path+'\db.db')
cur = conn.cursor()

这样就连接上了刚才的数据库。path+'\db.db'是数据库的路径及文件名,你可以手动输入路径,也可以将.py文件和db.db数据库文件放在同一目录下,系统自动计算路径,这是懒人方法。

2.2 查询数据库中有哪些表

我们似乎不知道db.db这个数据库中有什么,如何才能知道这个数据库中有哪些表呢?

cur.execute("SELECT name FROM sqlite_master WHERE type='table';")
Tables=cur.fetchall()
print(Tables)
# [('numbers',)]

2.3 删除数据库中的某个表

如果需要删除数据库中的某个表,可以执行以下命令:

cur.execute("drop table tablename;")

2.4 查询某个表的结构

cur.execute("PRAGMA table_info(numbers)")
print(cur.fetchall())
# [(0, 'id', 'integer', 0, None, 1), (1, 'number', 'varchar(20)', 1, None, 0)]

2.5 查询表中前50条记录

cur.execute("SELECT * from numbers limit 0,50;")
conn.commit 
data = cur.fetchall()
print(data)

2.6 查询表中所有记录

# 5.查询表中所有记录
cur.execute("SELECT * from numbers;") 
data_all = cur.fetchall()
a = len(data_all)
print('共有 '+ str(a) + ' 条记录')
#print(data)

2.7 查询表中不重复记录

cur.execute("SELECT distinct number from numbers;") 
data_distinct = cur.fetchall()
b = len(data_distinct)
print('共有 '+ str(b) +' 条不重复记录')
#print(data_distinct)

2.8 将老表中的不重复记录插入新表

# 创建一个新表
cur.execute('create table if not exists numbers_distinct (id integer primary key ,number varchar(20) NOT NULL)')
conn.commit()
# 插入数据
i = 0
for data in data_distinct:
    i += 1
    data = data[0]
    #print(data)
    cur.execute('insert into numbers_distinct values(?,?)',(i,data))
    conn.commit()

2.9 将特定结果写入文本文件(单列)

cur.execute("SELECT number from numbers_distinct limit 0,10;") 
datas = cur.fetchall()
#print(datas)
with open('datafile1.txt','w') as f1:
    for data in datas:
        f1.write(data[0]) 
        f1.flush()

注意:f1.flush()操作很重要!将缓冲区的数据写入文件中,否则文本文件为空白,导致写入失败。

2.10 将特定结果写入文本文件(多列)

cur.execute("SELECT * from numbers_distinct limit 0,10;") 
datas = cur.fetchall()
#print(datas)
with open('datafile2.txt','w') as f2:
    for data in datas:
        data0 = str(data[0]) # 将int类型转为str,否则write函数报错
        data = data0 + '    ' + data[1] # 在两列之间以Tab键分隔
        f2.write(data)
        f2.flush() 

2.11 将特定结果写入CSV文件(多列)

写入CSV文件和写入文本文件的方法基本相同,只需要将文件后缀改为 '.csv',并将分隔符改为英文状态下逗号即可。

with open('datafile3.csv','w') as f3:
    for data in datas:
        data0 = str(data[0]) # 将int类型转为str,否则write函数报错
        data = data0 + ',' + data[1] # 在两列之间以逗号键分隔
        f3.write(data) # data是元组类型
        f3.flush() # 重要!将缓冲区的数据写入文件中

2.12 办公自动化案例

本文以:将number_distingct表中的数据,以每50个为一组,分别存入一个文本文件为例,演示以下Python结合sqlite3数据库的办公自动化的惊艳效果。

1)源代码

"""
源代码已发布到【智能演示】微信公众号,后台回复 sqlite3 可获取下载链接。
"""
for n in range(int(b/50)+1):
    if 50*n+50 < b: # b为数据记录总数
        cur.execute('SELECT number from numbers_distinct limit ?,?',(50*n,50)) 
        datas = cur.fetchall()
        #print(datas)
        filename = str(50*n) + '-' + str(50*n+50) + '.txt'
        print('正在写入: ' + filename)
        with open(filename,'w') as f4:
            for data in datas:
                f4.write(data[0]) # data是元组类型
                f4.flush() # 重要!将缓冲区的数据写入文件中
    else:
        filename = str(50*n) + '-' + str(b) + '.txt'
        print('正在写入: ' + filename)
        with open(filename,'w') as f5: # 计算最后一个文本文件名称            
            cur.execute('SELECT number from numbers_distinct limit ?,?',(50*n+50,50)) 
            datas = cur.fetchall()
            for data in datas:
                f5.write(data[0]) # data是元组类型
                f5.flush() # 重要!将缓冲区的数据写入文件中
print('写入完成!共写入{}个TXT文件。'.format(n+1))

2)运行效果


数据导出动图

导出719个TXT文件,几秒钟就完成了。

3)重点代码解释

这个案例的重点是如何计算出每个TXT文件的名称。

我们可以计算出numbers_distinct表中共有35926条数据。

我们可以构建这样一个函数:filename = str(50*n) + '-' + str(50*n+50) + '.txt',用来计算每个导出的TXT文件名称。

但是最后一个文件的名称不能通过这个方法来构建,需要作以下简单的修改:filename = str(50*n) + '-' + str(b) + '.txt'

计算好每个TXT文件名称后,直接用write函数写入就可以了。

本文的所有源代码以发布到【智能演示】微信公众号,后台回复 sqlite3 就可以获取下载链接。

快来动动手试一下吧,享受一下办公自动化!

本文完,谢谢阅读!

本文首发【智能演示】微信公众号,欢迎关注,公众号后台回复【课程】领精选视频课程。


猜你喜欢:

1. 一文学懂Python数据结构之字符串基础知识

2. 这是format函数的骚操作???

3. 用Markdown,3分钟搞定微信公众号文章排版!

4. PPT居然还可以一键换色!学会这4招再也不怕色了……

5. 7步完成MySQL配置,极简教程,还不来试试?

6. 4 行代码实现批量、快速安装 Python 第三方库

7. 让程序帮你干活!批量转换任意文件夹下Word文档为PDF

8. 我用 Python 处理3万多条数据,只要几秒钟……


扫描下方二维码,
回复【课程】获取精选视频课程!

关注有好礼

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352

推荐阅读更多精彩内容

  • 使用的过程根据使用的函数大致分为如下几个过程: sqlite3_open() sqlite3_prepare() ...
    浪尖ON的水滴阅读 1,647评论 2 2
  • Python从网站上抓取的数据为了可以重复利用,一般都会存储下来,存储方式最简单的会选择存储到文本文件,常见的有方...
    苍简阅读 5,724评论 0 6
  • 个人学习批处理的初衷来源于实际工作;在某个迭代版本有个BS(安卓手游模拟器)大需求,从而在测试过程中就重复涉及到...
    Luckykailiu阅读 4,712评论 0 11
  • 创建数据库过程需要3个步骤: 1、使用sqlite3_open函数打开数据库; 2、使用sqlite3_exec函...
    lilinjianshu阅读 1,028评论 1 1
  • 每当放学时间,各个学校的门口总是给黑压压挤着一群接送的家长。待放学铃声一响,本就狭小的街道立刻臃肿膨胀起来,好像刚...
    一笑一尘缘2019阅读 110评论 0 0