欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python利用pyodbc庫將文件信息插入Access數(shù)據(jù)庫

 更新時(shí)間:2023年08月13日 09:47:10   作者:winfredzhang  
在日常編程工作中,我們經(jīng)常需要處理文件和文件夾,所以本文將介紹如何使用Python編程語言和wxPython庫創(chuàng)建一個(gè)簡單的文件瀏覽器界面,使用戶能夠選擇文件夾并將文件信息插入到Access數(shù)據(jù)庫中,需要的可以參考下

簡介

在日常編程工作中,我們經(jīng)常需要處理文件和文件夾。有時(shí),我們需要遍歷文件夾中的所有文件,并將文件的路徑、類型、文件名以及修改日期和創(chuàng)建日期等信息保存到數(shù)據(jù)庫中。本文將介紹如何使用Python編程語言和wxPython庫創(chuàng)建一個(gè)簡單的文件瀏覽器界面,使用戶能夠選擇文件夾并將文件信息插入到Access數(shù)據(jù)庫中。

準(zhǔn)備工作

在開始之前,確保你的計(jì)算機(jī)上已經(jīng)安裝了以下軟件和庫:

  • Python編程語言(推薦使用最新版本)
  • wxPython庫(用于創(chuàng)建界面)
  • pyodbc庫(用于連接和操作Access數(shù)據(jù)庫)

你可以使用pip命令安裝wxPython和pyodbc庫:

pip install wxPython
pip install pyodbc

創(chuàng)建界面

首先,我們需要使用wxPython庫創(chuàng)建一個(gè)簡單的界面,使用戶能夠選擇文件夾并查看文件信息。以下是創(chuàng)建界面的主要步驟:

1.導(dǎo)入所需的庫:

import wx
import wx.grid
import os
import pyodbc
from datetime import datetime

2.創(chuàng)建數(shù)據(jù)庫連接:

db_path = r'C:\path\to\your\database.accdb'
conn_str = r'DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=' + db_path
conn = pyodbc.connect(conn_str)
cursor = conn.cursor()

3.創(chuàng)建主窗口:

class MainFrame(wx.Frame):
    def __init__(self, parent):
        super().__init__(parent, title='File Explorer', size=(800, 600))
        self.panel = wx.Panel(self)
        # 創(chuàng)建選擇文件夾按鈕和文件列表表格
        self.select_folder_btn = wx.Button(self.panel, label='Select Folder')
        self.file_list_grid = wx.grid.Grid(self.panel)
        # 設(shè)置文件列表表格的列名
        self.file_list_grid.CreateGrid(0, 5)
        self.file_list_grid.SetColLabelValue(0, 'Path')
        self.file_list_grid.SetColLabelValue(1, 'Type')
        self.file_list_grid.SetColLabelValue(2, 'Filename')
        self.file_list_grid.SetColLabelValue(3, 'File Modify')
        self.file_list_grid.SetColLabelValue(4, 'File Create')
        # 創(chuàng)建垂直布局管理器
        sizer = wx.BoxSizer(wx.VERTICAL)
        sizer.Add(self.select_folder_btn, 0, wx.ALL, 5)
        sizer.Add(self.file_list_grid, 1, wx.EXPAND | wx.ALL, 5)
        self.panel.SetSizer(sizer)
        # 綁定選擇文件夾按鈕的點(diǎn)擊事件
        self.select_folder_btn.Bind(wx.EVT_BUTTON, self.on_select_folder)

4.處理文件夾選擇事件:

def on_select_folder(self, event):
    # 打開文件夾選擇對(duì)話框
    dlg = wx.DirDialog(self, "Select a folder")
    if dlg.ShowModal() == wx.ID_OK:
        folder_path = dlg.GetPath()
        self.process_files(folder_path)
    dlg.Destroy()

5.處理文件信息處理:

def process_files(self, folder_path):
    # 清空文件列表表格
    self.file_list_grid.ClearGrid()
    # 遍歷文件夾中的文件
    for root, dirs, files in os.walk(folder_path):
        for file in files:
            file_path = os.path.join(root, file)
            file_type = os.path.splitext(file_path)[1]
            file_name = os.path.basename(file_path)
            file_modify = datetime.fromtimestamp(os.path.getmtime(file_path))
            file_create = datetime.fromtimestamp(os.path.getctime(file_path))
            # 將文件信息插入數(shù)據(jù)庫
            cursor.execute('''
                INSERT INTO path (path, type, filename, filemodify, filecreate)
                VALUES (?, ?, ?, ?, ?)
            ''', file_path, file_type, file_name, file_modify, file_create)
            conn.commit()
            # 顯示文件信息在文件列表表格中
            row_count =self.file_list_grid.GetNumberRows()
            self.file_list_grid.AppendRows(1)
            self.file_list_grid.SetCellValue(row_count, 0, file_path)
            self.file_list_grid.SetCellValue(row_count, 1, file_type)
            self.file_list_grid.SetCellValue(row_count, 2, file_name)
            self.file_list_grid.SetCellValue(row_count, 3, str(file_modify))
            self.file_list_grid.SetCellValue(row_count, 4, str(file_create))

6.運(yùn)行應(yīng)用程序:

if __name__ == '__main__':
    app = wx.App()
    frame = MainFrame(None)
    frame.Show()
    app.MainLoop()

全部代碼

import wx
import wx.grid
import os
import pyodbc
from datetime import datetime
# 數(shù)據(jù)庫連接信息
db_path = r'./database1.accdb'
conn_str = r'DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=' + db_path
# 創(chuàng)建數(shù)據(jù)庫連接
conn = pyodbc.connect(conn_str)
cursor = conn.cursor()
# # 創(chuàng)建表格(如果不存在)
# cursor.execute('''
#     CREATE TABLE IF NOT EXISTS path (
#         id AUTOINCREMENT PRIMARY KEY,
#         path TEXT,
#         type TEXT,
#         filename TEXT,
#         filemodify DATETIME,
#         filecreate DATETIME
#     )
# ''')
# conn.commit()
# 創(chuàng)建主窗口
class MainFrame(wx.Frame):
    def __init__(self, parent):
        super().__init__(parent, title='File Explorer', size=(800, 600))
        self.panel = wx.Panel(self)
        # 創(chuàng)建選擇文件夾按鈕和文件列表表格
        self.select_folder_btn = wx.Button(self.panel, label='Select Folder')
        self.file_list_grid = wx.grid.Grid(self.panel)
        # 設(shè)置文件列表表格的列名
        self.file_list_grid.CreateGrid(0, 5)
        self.file_list_grid.SetColLabelValue(0, 'Path')
        self.file_list_grid.SetColLabelValue(1, 'Type')
        self.file_list_grid.SetColLabelValue(2, 'Filename')
        self.file_list_grid.SetColLabelValue(3, 'File Modify')
        self.file_list_grid.SetColLabelValue(4, 'File Create')
        # 創(chuàng)建垂直布局管理器
        sizer = wx.BoxSizer(wx.VERTICAL)
        sizer.Add(self.select_folder_btn, 0, wx.ALL, 5)
        sizer.Add(self.file_list_grid, 1, wx.EXPAND | wx.ALL, 5)
        self.panel.SetSizer(sizer)
        # 綁定選擇文件夾按鈕的點(diǎn)擊事件
        self.select_folder_btn.Bind(wx.EVT_BUTTON, self.on_select_folder)
    def on_select_folder(self, event):
        # 打開文件夾選擇對(duì)話框
        dlg = wx.DirDialog(self, "Select a folder")
        if dlg.ShowModal() == wx.ID_OK:
            folder_path = dlg.GetPath()
            self.process_files(folder_path)
        dlg.Destroy()
    def process_files(self, folder_path):
        # 清空文件列表表格
        self.file_list_grid.ClearGrid()
        # 遍歷文件夾中的文件
        for root, dirs, files in os.walk(folder_path):
            for file in files:
                file_path = os.path.join(root, file)
                file_type = os.path.splitext(file_path)[1]
                file_name = os.path.basename(file_path)
                file_modify = datetime.fromtimestamp(os.path.getmtime(file_path))
                file_create = datetime.fromtimestamp(os.path.getctime(file_path))
                # 將文件信息插入數(shù)據(jù)庫
                cursor.execute('''
                    INSERT INTO path (path, type, filename, filemodify, filecreate)
                    VALUES (?, ?, ?, ?, ?)
                ''', file_path, file_type, file_name, file_modify, file_create)
                conn.commit()
                # 顯示文件信息在文件列表表格中
                row_count = self.file_list_grid.GetNumberRows()
                self.file_list_grid.InsertRows(row_count)
                self.file_list_grid.SetCellValue(row_count, 0, file_path)
                self.file_list_grid.SetCellValue(row_count, 1, file_type)
                self.file_list_grid.SetCellValue(row_count, 2, file_name)
                self.file_list_grid.SetCellValue(row_count, 3, str(file_modify))
                self.file_list_grid.SetCellValue(row_count, 4, str(file_create))
        # 調(diào)整文件列表表格的列寬
        self.file_list_grid.AutoSizeColumns()
# 創(chuàng)建應(yīng)用程序?qū)ο?
app = wx.App()
# 創(chuàng)建主窗口對(duì)象并顯示
frame = MainFrame(None)
frame.Show()
# 啟動(dòng)應(yīng)用程序主循環(huán)
app.MainLoop()
# 關(guān)閉數(shù)據(jù)庫連接
cursor.close()
conn.close()

創(chuàng)建Access數(shù)據(jù)庫表

在運(yùn)行以上代碼之前,你需要在Access數(shù)據(jù)庫中創(chuàng)建一個(gè)名為 “path” 的表,用于存儲(chǔ)文件信息??梢园凑找韵虏襟E創(chuàng)建表:

1.打開Access數(shù)據(jù)庫文件。

2.在 “數(shù)據(jù)庫工具” 面板中,選擇 “表設(shè)計(jì)”。

3.在 “表設(shè)計(jì)” 視圖中,創(chuàng)建以下字段:

  • path:文本類型,用于存儲(chǔ)文件路徑。
  • type:文本類型,用于存儲(chǔ)文件類型。
  • filename:文本類型,用于存儲(chǔ)文件名。
  • filemodify:日期/時(shí)間類型,用于存儲(chǔ)文件修改日期。
  • filecreate:日期/時(shí)間類型,用于存儲(chǔ)文件創(chuàng)建日期。

4.保存表并關(guān)閉Access數(shù)據(jù)庫。

運(yùn)行代碼

保存以上代碼為 fileinfotoaccess.py 文件,并確保你的計(jì)算機(jī)上已經(jīng)安裝了所需的庫和軟件。接下來,你可以運(yùn)行該文件,選擇一個(gè)文件夾,并將文件信息插入到Access數(shù)據(jù)庫中。你還可以在界面中查看文件信息。

本文介紹了如何使用Python和wxPython庫創(chuàng)建一個(gè)簡單的文件瀏覽器界面,并將文件信息插入到Access數(shù)據(jù)庫中。你可以根據(jù)自己的需求對(duì)代碼進(jìn)行修改和擴(kuò)展,以適應(yīng)更多功能。

到此這篇關(guān)于Python利用pyodbc庫將文件信息插入Access數(shù)據(jù)庫的文章就介紹到這了,更多相關(guān)Python pyodbc內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python下載網(wǎng)絡(luò)小說實(shí)例代碼

    Python下載網(wǎng)絡(luò)小說實(shí)例代碼

    這篇文章主要介紹了Python下載網(wǎng)絡(luò)小說實(shí)例代碼,分享了相關(guān)代碼示例,小編覺得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-02-02
  • Python爬蟲中IP池的使用小結(jié)

    Python爬蟲中IP池的使用小結(jié)

    在網(wǎng)絡(luò)爬蟲的世界中,IP池是一個(gè)關(guān)鍵的概念,它允許爬蟲程序在請(qǐng)求網(wǎng)頁時(shí)使用多個(gè)IP地址,從而降低被封禁的風(fēng)險(xiǎn),提高爬蟲的穩(wěn)定性和效率,本文將深入探討Python爬蟲中IP池的使用,以及如何構(gòu)建和維護(hù)一個(gè)可靠的IP池,感興趣的朋友一起看看吧
    2024-01-01
  • Python文件去除注釋的方法

    Python文件去除注釋的方法

    這篇文章主要介紹了Python文件去除注釋的方法,涉及Python正則表達(dá)式及文件操作的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05
  • python標(biāo)準(zhǔn)庫學(xué)習(xí)之sys模塊詳解

    python標(biāo)準(zhǔn)庫學(xué)習(xí)之sys模塊詳解

    sys模塊是最常用的和python解釋器交互的模塊,sys模塊可供訪問由解釋器(interpreter)使用或維護(hù)的變量和與解釋器進(jìn)行交互的函數(shù),下面這篇文章主要給大家介紹了關(guān)于python標(biāo)準(zhǔn)庫學(xué)習(xí)之sys模塊的相關(guān)資料,需要的朋友可以參考下
    2022-08-08
  • python神經(jīng)網(wǎng)絡(luò)MobileNetV2模型的復(fù)現(xiàn)詳解

    python神經(jīng)網(wǎng)絡(luò)MobileNetV2模型的復(fù)現(xiàn)詳解

    這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)MobileNetV2模型的復(fù)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • 利用python計(jì)算時(shí)間差(返回天數(shù))

    利用python計(jì)算時(shí)間差(返回天數(shù))

    這篇文章主要給大家介紹了關(guān)于如何利用python計(jì)算時(shí)間差(返回天數(shù))的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用python具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • python實(shí)現(xiàn)請(qǐng)求數(shù)據(jù)包簽名

    python實(shí)現(xiàn)請(qǐng)求數(shù)據(jù)包簽名

    這篇文章主要介紹了python實(shí)現(xiàn)請(qǐng)求數(shù)據(jù)包簽名,主要以python怎么快速對(duì)請(qǐng)求體做一次簽名為主題,塑造實(shí)現(xiàn)請(qǐng)求數(shù)據(jù)包簽名過程,具有一定得參考價(jià)值,需要的小伙伴可以參考一下
    2022-02-02
  • python 利用turtle模塊畫出沒有角的方格

    python 利用turtle模塊畫出沒有角的方格

    今天小編就為大家分享一篇python 利用turtle模塊畫出沒有角的方格,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • window7下的python2.7版本和python3.5版本的opencv-python安裝過程

    window7下的python2.7版本和python3.5版本的opencv-python安裝過程

    這篇文章主要介紹了window7下的python2.7版本和python3.5版本的opencv-python安裝過程,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-10-10
  • python正則表達(dá)式面試題解答

    python正則表達(dá)式面試題解答

    這篇文章主要為大家分析了python正則表達(dá)式常見面試題,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01

最新評(píng)論