利用python *** 作SQLite数据库及文件 *** 作详解

利用python *** 作SQLite数据库及文件 *** 作详解,第1张

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

前言

最近在工作中遇到一个需求,就是要把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;

总结

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

总结

以上是内存溢出为你收集整理的利用python *** 作SQLite数据库及文件 *** 作详解全部内容,希望文章能够帮你解决利用python *** 作SQLite数据库及文件 *** 作详解所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1201555.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存