使用Python和pyodbc库将文件信息插入Access数据库

news2025/1/11 14:21:10

将文件信息插入 Access 数据库的博客文章示例:


简介:
在日常编程工作中,我们经常需要处理文件和文件夹。有时,我们需要遍历文件夹中的所有文件,并将文件的路径、类型、文件名以及修改日期和创建日期等信息保存到数据库中。本文将介绍如何使用Python编程语言和wxPython库创建一个简单的文件浏览器界面,使用户能够选择文件夹并将文件信息插入到Access数据库中。
在这里插入图片描述

准备工作

在开始之前,确保你的计算机上已经安装了以下软件和库:

  • Python编程语言(推荐使用最新版本)
  • wxPython库(用于创建界面)
  • pyodbc库(用于连接和操作Access数据库)

你可以使用pip命令安装wxPython和pyodbc库:

pip install wxPython
pip install pyodbc

创建界面

首先,我们需要使用wxPython库创建一个简单的界面,使用户能够选择文件夹并查看文件信息。以下是创建界面的主要步骤:

  1. 导入所需的库:
import wx
import wx.grid
import os
import pyodbc
from datetime import datetime
  1. 创建数据库连接:
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()
  1. 创建主窗口:
class MainFrame(wx.Frame):
    def __init__(self, parent):
        super().__init__(parent, title='File Explorer', size=(800, 600))
        
        self.panel = wx.Panel(self)
        
        # 创建选择文件夹按钮和文件列表表格
        self.select_folder_btn = wx.Button(self.panel, label='Select Folder')
        self.file_list_grid = wx.grid.Grid(self.panel)
        
        # 设置文件列表表格的列名
        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')
        
        # 创建垂直布局管理器
        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)
        
        # 绑定选择文件夹按钮的点击事件
        self.select_folder_btn.Bind(wx.EVT_BUTTON, self.on_select_folder)
  1. 处理文件夹选择事件:
def on_select_folder(self, event):
    # 打开文件夹选择对话框
    dlg = wx.DirDialog(self, "Select a folder")
    if dlg.ShowModal() == wx.ID_OK:
        folder_path = dlg.GetPath()
        self.process_files(folder_path)
    dlg.Destroy()
  1. 处理文件信息处理:
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))
            
            # 将文件信息插入数据库
            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))
  1. 运行应用程序:
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

# 数据库连接信息
db_path = r'./database1.accdb'
conn_str = r'DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=' + db_path

# 创建数据库连接
conn = pyodbc.connect(conn_str)
cursor = conn.cursor()

# # 创建表格(如果不存在)
# cursor.execute('''
#     CREATE TABLE IF NOT EXISTS path (
#         id AUTOINCREMENT PRIMARY KEY,
#         path TEXT,
#         type TEXT,
#         filename TEXT,
#         filemodify DATETIME,
#         filecreate DATETIME
#     )
# ''')
# conn.commit()

# 创建主窗口
class MainFrame(wx.Frame):
    def __init__(self, parent):
        super().__init__(parent, title='File Explorer', size=(800, 600))
        
        self.panel = wx.Panel(self)
        
        # 创建选择文件夹按钮和文件列表表格
        self.select_folder_btn = wx.Button(self.panel, label='Select Folder')
        self.file_list_grid = wx.grid.Grid(self.panel)
        
        # 设置文件列表表格的列名
        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')
        
        # 创建垂直布局管理器
        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)
        
        # 绑定选择文件夹按钮的点击事件
        self.select_folder_btn.Bind(wx.EVT_BUTTON, self.on_select_folder)
    
    def on_select_folder(self, event):
        # 打开文件夹选择对话框
        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))
                
                # 将文件信息插入数据库
                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))
        
        # 调整文件列表表格的列宽
        self.file_list_grid.AutoSizeColumns()
        
# 创建应用程序对象
app = wx.App()

# 创建主窗口对象并显示
frame = MainFrame(None)
frame.Show()

# 启动应用程序主循环
app.MainLoop()

# 关闭数据库连接
cursor.close()
conn.close()

创建Access数据库表

在运行以上代码之前,你需要在Access数据库中创建一个名为 “path” 的表,用于存储文件信息。可以按照以下步骤创建表:

  1. 打开Access数据库文件。
  2. 在 “数据库工具” 面板中,选择 “表设计”。
  3. 在 “表设计” 视图中,创建以下字段:
    • path:文本类型,用于存储文件路径。
    • type:文本类型,用于存储文件类型。
    • filename:文本类型,用于存储文件名。
    • filemodify:日期/时间类型,用于存储文件修改日期。
    • filecreate:日期/时间类型,用于存储文件创建日期。
  4. 保存表并关闭Access数据库。

运行代码

保存以上代码为 fileinfotoaccess.py 文件,并确保你的计算机上已经安装了所需的库和软件。接下来,你可以运行该文件,选择一个文件夹,并将文件信息插入到Access数据库中。你还可以在界面中查看文件信息。

本文介绍了如何使用Python和wxPython库创建一个简单的文件浏览器界面,并将文件信息插入到Access数据库中。你可以根据自己的需求对代码进行修改和扩展,以适应更多功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/870797.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于MIV的神经网络变量筛选

1.案例背景 一般神经网络中所包含的网络输人数据是研究者根据专业知识和经验预先选择好的,然而在许多实际应用中,由于没有清晰的理论依据,神经网络所包含的自变量即网络输入特征难以预先确定,如果将一些不重要的自变量也引入神经网络,会降低模型的精度,因此选择有意义的自变量特…

Flask 上下文是什么 ?

哈喽大家好,我是咸鱼。今天我们来聊聊什么是 Flask 上下文 咸鱼在刚接触到这个概念的时候脑子里蹦出的第一个词是 CPU 上下文 今天咸鱼希望通过这篇文章,让大家能够对 Flask 上下文设计的初衷以及应用有一个基本的了解 Flask 上下文 我们在使用 Flask 开…

【算法基础19-模拟队列】

模拟队列 算法示意图 算法的伪代码 例题 实现一个队列,队列初始为空,支持四种操作: push x – 向队尾插入一个数 x;pop – 从队头弹出一个数;empty – 判断队列是否为空;query – 查询队头元素。 现在要…

不做Linux就没前途吗?

答案当然是——并不会 我晚上回来的时候跟一个今年的毕业生聊天,他入职了一家公司,但是从事的不是Linux相关的工作。 我这里想说的是,做Linux可以赚钱,Linux现在是全世界最牛逼的开源项目一点都不为过,但是Linux也不是…

环境与能源创新专题:地级市绿色创新、碳排放与环境规制数据

数据简介:推动绿色发展,促进人与自然和谐共生是重大战略举措。绿色发展强调“绿水青山就是金山银山”,人与自然和谐共生重在正确处理生态环境保护与经济发展的关系。在着力于实现绿色发展的过程中,绿色创新是绿色发展的重要驱动因…

时序预测 | Matlab实现基于RF随机森林的电力负荷预测模型

文章目录 效果一览基本介绍模型描述源码设计学习小结参考资料效果一览 基本介绍 时序预测 | Matlab实现基于RF随机森林的电力负荷预测模型 电力负荷预测是指通过对历史电力负荷数据分析,来预测未来某个时间段内的电力负荷需求。这项预测对于电力系统的运行和调度至关重要,可以…

CSS实现左侧固定,右侧自适应(5种方法)

<div class"father"><!-- 左右div不能调换顺序来写 --><div class"left">固定宽度区</div><div class"right">自适应区</div> </div> 一、利用左侧浮动float右侧margin-left /* 利用浮动floatmargin…

【Linux操作系统】深入理解系统调用中的read和write函数

在操作系统中&#xff0c;系统调用是用户程序与操作系统之间进行交互的重要方式。其中&#xff0c;read和write函数是常用的系统调用函数&#xff0c;用于在用户程序和操作系统之间进行数据的读取和写入。本文将深入介绍read和write函数的工作原理、用法以及示例代码&#xff0…

chatGPT小白快速入门-002:一文看懂什么是chatGPT

一、前言 本文是《chatGPT小白快速入门培训课程》的第002篇文章&#xff1a;一文看懂什么是chatGPT&#xff0c;全部内容采用chatGPT和chatGPT开源平替软件生成。完整内容大纲详见&#xff1a;《chatGPT小白快速入门课程大纲》。 本系列文章&#xff0c;参与&#xff1a; AIGC…

对doccano自动标注使用的默认UIE模型进行微调以提高特定领域的实体识别能力,提高标注速度

预处理doccano标注的数据 该章节详细说明如何通过doccano.py脚本对doccano平台导出的标注数据进行转换&#xff0c;一键生成训练/验证/测试集。 在本地部署UIE模型 下载模型压缩包&#xff1a; 本来是要通过一定的方法&#xff08;GitZip&#xff09;才能在整体的大项目仓库…

C++初阶之一篇文章教会你list(模拟实现)

list&#xff08;模拟实现&#xff09; list模拟实现list_node节点结构定义std::__reverse_iterator逆向迭代器实现list迭代器 __list_iterator定义list类成员定义list成员函数定义1.begin()、end()、rbegin()和rend()2.empty_init()3.构造函数定义4.swap5.析构函数定义6.clear…

HCIP BGP 实验

​​​​​​​ 拓扑图 r1: <Huawei>sys [Huawei]sys r1 [r1]int g 0/0/1 [r1-GigabitEthernet0/0/1]ip add 12.1.1.1 24 [r1-GigabitEthernet0/0/1]int lo0 [r1-LoopBack0]ip add 1.1.1.1 24 [r1-LoopBack0]ospf network-type broadcast [r1-bgp]peer 12.1.1.2 as-nu…

Spring Cloud 面试突击2

Spring Cloud 面试突击2 高并发&#xff1a;是一种系统运行过程中遇到的短时间大量的请求操作 响应时间&#xff1a; 吞吐量&#xff1a; QPS&#xff1a;数据库为维度 TPS 并发用户数 并发的维度&#xff1a;很多的 并发是不是达到的当前系统的瓶颈 缓存 &#xff08…

SpingBoot-Vue前后端——实现CRUD

目录​​​​​​​ 一、实例需求 ⚽ 二、代码实现 &#x1f3cc; 数据库 &#x1f440; 后端实现 &#x1f4eb; 前端实现 &#x1f331; 三、源码下载 &#x1f44b; 一、实例需求 ⚽ 实现一个简单的CRUD&#xff0c;包含前后端交互。 二、代码实现 &#x1f3cc; 数…

阶梯费用计算(配置化_最小demo)

本文旨在提供一种配置化思路计算阶梯费用&#xff0c;更高级的做法则是通过数据库配置&#xff0c;注册中心等&#xff1b;在表达式上可以采用自定义或者spel表达式等其他方式进行处理&#xff1b;(代码仅展示最小demo,部分不完善地方自行补充) 思路&#xff1a;N个区间对应N个…

重置mariadb数据库密码

使用场景重置步骤 重置数据库root用户密码为空重置数据库密码 文档暂时只支持未开启ha时manager使用的mariadb&#xff0c;开启ha的txsql和kundb类似&#xff0c;my.cnf文件地址和登录数据库命令不同 使用场景 manager数据库密码是通过调用接口并根据db.properties文件获取的…

众和转债,宏微转债,阳谷转债上市价格预测

众和转债 基本信息 转债名称&#xff1a;众和转债&#xff0c;评级&#xff1a;AA&#xff0c;发行规模&#xff1a;13.75亿元。 正股名称&#xff1a;新疆众和&#xff0c;今日收盘价&#xff1a;8.14元&#xff0c;转股价格&#xff1a;8.2元。 当前转股价值 转债面值 / 转股…

基于SqlSugar的开发框架循序渐进介绍-- 快速构建系统参数管理界面

在参照一些行业系统软件的时候&#xff0c;发现一个做的挺不错的系统功能-系统参数管理&#xff0c;相当于把任何一个基础的系统参数碎片化进行管理&#xff0c;每次可以读取一个值进行管理&#xff0c;这样有利于我们快速的处理业务需求&#xff0c;是一个挺好的功能。本篇随笔…

【FastColoredTextBox】C# 开源文本编辑控件

主界面截图 使用Demos演示 FastColoredTextBox 是一个用于在 C# 程序中实现高亮语法着色、代码编辑和文本显示的自定义控件。它提供了许多功能&#xff0c;包括&#xff1a; 语法高亮&#xff1a;FastColoredTextBox 支持多种语言的语法高亮&#xff0c;可以根据语法规则将不同…

Linux 终端操作命令(2)内部命令

Linux 终端操作命令 也称Shell命令&#xff0c;是用户与操作系统内核进行交互的命令解释器&#xff0c;它接收用户输入的命令并将其传递给操作系统进行执行&#xff0c;可分为内部命令和外部命令。内部命令是Shell程序的一部分&#xff0c;而外部命令是独立于Shell的可执行程序…