利用python操作SQLite数据库及文件操作详解,
利用python操作SQLite数据库及文件操作详解,
前言
最近在工作中遇到一个需求,就是要把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实现字符串与数组相互转换功能示例,python相互转
- Python中列表list以及list与数组array的相互转换实现方法,
- Python实现二维数组按照某行或列排序的方法【numpy lex
- Python实现针对含中文字符串的截取功能示例,
- 详谈python read readline readlines的区别,pythonreadlines
- Python字符串和字典相关操作的实例详解,python字符串
- python数据结构之列表和元组的详解,python数据结构详解
- python3.4下django集成使用xadmin后台的方法,djangoxadmin
- CentOS下使用yum安装python-pip失败的完美解决方法,cento
- python使用opencv读取图片的实例,
评论关闭