时间:2021-05-22
前言
最近在工作中遇到一个需求,就是要把SQLite数据中没有存储的文件名的文件删除掉,想来想去还是决定用python。所以也就花了一天半的时间学习了下,随手写了个小例子,下面话不多说了,感兴趣的朋友们一起来看看详细的介绍吧。
直接上代码
要用到的头文件包
#coding=utf-8#!/usr/bin/python#!/usr/bin/env pythonimport osimport shutilimport 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;总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了PHP实现的sqlite数据库连接类。分享给大家供大家参考。具体实现方法如下:该sqlite数据库连接类就是利用了php与sqlite进行连接操作
在VC++中通过sqlite3.dll接口对sqlite数据库进行操作,包括打开数据库,插入,查询数据库等,如果操作接口输入参数包含中文字符,会导致操作异常。例
Python中对sqlite3数据库进行操作时,经常需要用到字段名,然而对于sqlite使用select语句并不能象MySql等数据库一样返回带字段名的字典数据
在IOS中使用Sqlite来处理数据。如果你已经了解了SQL,那你可以很容易的掌握SQLite数据库的操作。iOS对于数据库的操作:增加、删除、查找、修改具体介
本篇博文主要介绍Python连接各种数据库的方法及简单使用包括关系数据库:sqlite,mysql,mssql非关系数据库:MongoDB,Redis代码写的比