python打开sqlite文件_利用python操作SQLite数据库及文件操作详解

本文介绍了如何使用Python连接SQLite数据库,通过对比数据库中记录的文件名与实际文件,删除数据库中不存在的文件。首先引入os、shutil和sqlite3库,然后遍历指定目录下的文件,检查文件是否存在于数据库中,如果不存在则删除。最后,关闭数据库连接并打印统计信息。
摘要由CSDN通过智能技术生成

前言

最近在工作中遇到一个需求,就是要把SQLite数据中没有存储的文件名的文件删除掉,想来想去还是决定用python。所以也就花了一天半的时间学习了下,随手写了个小例子,下面话不多说了,感兴趣的朋友们一起来看看详细的介绍吧。

直接上代码

要用到的头文件包

#coding=utf-8

#!/usr/bin/python

#!/usr/bin/env python

import os

import shutil

import sqlite3

定义记录变量

#记录所文件数

sumCount=0;

#记录留存文件数

count=0;

#记录删除文件数

delCount=0;

#定义存储遍历所有文件数组

delList = []

#文件存储路径

delDir = "/Users/liudengtan/Desktop/testFile/"

#获取路径下所有文件

delList = os.listdir(delDir)

#打开连接数据库

conn = sqlite3.connect('images.db')

print "开始处理...";

把文件目录下的所有文件与数据库的存的对比,如果文件在数据中,就存留,否则删除文件

#遍历

for f in delList:

#获取到文件路径

filePath = os.path.join(delDir, f)

if os.path.isfile(filePath):

sumCount=sumCount+1

#将文件全路径中存储路径替换,只留文件名

fileName=filePath.replace(delDir,'')

#数据库查看当前文件名是否存在

cursor = conn.execute("SELECT image FROM '表名' where image=(?)",(fileName))

res = cursor.fetchall()

#条件判断>0文件存在

if len(res) > 0:

count = count + 1;

else:#文件不存在将其删除

if os.path.isfile(delDir + fileName):

#删除文件操作

os.remove(delDir + fileName)

print delDir + fileName + " 删除!"

delCount = delCount + 1;

#关闭数据库

conn.close()

print "处里结束:";

print "所有文件总数 : ",sumCount;

print "删除文件数 : ",delCount;

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对软件开发网的支持。

您可能感兴趣的文章:Python SQLite3数据库日期与时间常见函数用法分析Python实现读取TXT文件数据并存进内置数据库SQLite3的方法Python开发SQLite3数据库相关操作详解【连接,查询,插入,更新,删除,关闭等】Python轻量级ORM框架Peewee访问sqlite数据库的方法详解Python实现将sqlite数据库导出转成Excel(xls)表的方法Python3实现连接SQLite数据库的方法python操作数据库之sqlite3打开数据库、删除、修改示例Python操作SQLite数据库过程解析

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值