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

作者:刘登坛 时间:2024-01-25 20:54:39 

前言

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

来源:https://segmentfault.com/a/1190000011238311

标签:python,sqlite数据库,文件操作
0
投稿

猜你喜欢

  • 详解Python3定时器任务代码

    2023-10-15 14:50:26
  • 分享unittest单元测试框架中几种常用的用例加载方法

    2023-04-25 06:53:34
  • 浅析pandas随机排列与随机抽样

    2022-03-29 21:19:00
  • Python 可爱的大小写

    2021-05-15 12:34:18
  • PHP格式化显示时间date()函数案例讲解

    2023-06-13 06:45:34
  • YOLOv5车牌识别实战教程(五)字符分割与识别

    2022-04-07 07:38:25
  • SQLServer中的切割字符串SplitString函数

    2011-12-01 08:14:09
  • 超越质检员——看图购beta版的思考

    2009-04-15 12:11:00
  • Python eval函数原理及用法解析

    2021-04-29 05:17:18
  • OpenCV模板匹配matchTemplate的实现

    2021-08-09 15:51:51
  • 使用fdopen实现对Python进程产生的文件进行权限最小化配置

    2021-04-20 15:49:05
  • Python通过命令开启http.server服务器的方法

    2022-10-08 01:42:41
  • angularJS实现表格部分列展开缩起示例代码

    2024-04-16 10:40:42
  • MYSQL使用.frm恢复数据表结构的实现方法

    2024-01-24 21:52:27
  • Python中循环后使用list.append()数据被覆盖问题的解决

    2023-02-08 20:45:49
  • 栅格:从混乱到秩序

    2008-07-02 12:09:00
  • Pandas DataFrame 取一行数据会得到Series的方法

    2023-08-28 04:25:13
  • Ubuntu下mysql与mysql workbench安装教程

    2024-01-14 23:08:40
  • 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器

    2024-01-18 04:28:24
  • PyCharm 设置数据库,查询数据库语句方式

    2024-01-19 22:05:07
  • asp之家 网络编程 m.aspxhome.com