ホームページ  >  記事  >  バックエンド開発  >  PythonでSQLiteデータベースやファイル操作を操作する例を詳しく解説

PythonでSQLiteデータベースやファイル操作を操作する例を詳しく解説

黄舟
黄舟オリジナル
2017-09-23 11:28:172052ブラウズ

この記事では、主に Python を使用した SQLite データベースとファイルの操作に関する関連情報をサンプル コードを通じて詳しく紹介します。この記事は、学習や仕事に役立つ特定の学習価値があります。以下に来て私と一緒に学びましょう。

前書き

最近、仕事で SQLite データに保存されているファイル名のないファイルを削除する必要があることに遭遇しました。よく考えた結果、Python を使用することにしました。そこで私は 1 日半をかけて検討し、小さな例を書きました。詳細については省略します。興味のある方は詳細な紹介を参照してください。

コードに直接移動

使用するヘッダーファイルパッケージ


#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 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。