這篇文章主要為大家介紹了關於利用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操作SQLite資料庫與檔案操作的實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!