Python 将文件夹中的图片信息导入到 Excel 的表格

2024-05-25 07:36

本文主要是介绍Python 将文件夹中的图片信息导入到 Excel 的表格,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

引言

在数据处理和管理的日常任务中,经常需要将文件夹中的图片文件信息(如文件名、路径、创建日期、大小、分辨率等)整理成一个 Excel 表格。这篇博客将介绍如何使用 Python 中的 wxPython 模块创建一个 GUI 应用,用户可以通过这个应用选择一个文件夹,并将其中的图片信息导入到 Excel 表格中。
C:\pythoncode\new\jpeginfoTOexcel.py

准备工作

在开始之前,请确保已安装以下 Python 模块:

  • wxPython:用于创建 GUI 界面
  • openpyxl:用于操作 Excel 文件
  • Pillow:用于处理图像文件,获取图片分辨率

使用以下命令安装这些模块:

pip install wxPython openpyxl Pillow

实现步骤

第一步:创建 wxPython 界面

首先,我们需要创建一个简单的 GUI 界面,允许用户选择一个文件夹,并点击按钮生成包含图片信息的 Excel 文件。

import wx
import os
from openpyxl import Workbook
from PIL import Image
from datetime import datetimeclass ImageInfoApp(wx.Frame):def __init__(self, parent, title):super(ImageInfoApp, self).__init__(parent, title=title, size=(500, 300))panel = wx.Panel(self)vbox = wx.BoxSizer(wx.VERTICAL)self.dir_picker = wx.DirPickerCtrl(panel, message="Choose a directory")vbox.Add(self.dir_picker, flag=wx.EXPAND | wx.ALL, border=10)self.generate_btn = wx.Button(panel, label="Generate Excel")vbox.Add(self.generate_btn, flag=wx.EXPAND | wx.ALL, border=10)self.Bind(wx.EVT_BUTTON, self.on_generate_excel, self.generate_btn)panel.SetSizer(vbox)self.Centre()self.Show()def on_generate_excel(self, event):dir_path = self.dir_picker.GetPath()if not dir_path:wx.MessageBox('Please select a directory first', 'Error', wx.OK | wx.ICON_ERROR)return# Create a new Excel workbook and select the active worksheetwb = Workbook()ws = wb.activews.append(['Filename', 'Path', 'Creation Date', 'Size (KB)', 'Resolution'])for root, dirs, files in os.walk(dir_path):for file in files:if file.lower().endswith(('.png', '.jpg', '.jpeg', '.bmp', '.gif')):file_path = os.path.join(root, file)creation_date = datetime.fromtimestamp(os.path.getctime(file_path)).strftime('%Y-%m-%d %H:%M:%S')size = os.path.getsize(file_path) / 1024  # Size in KBtry:with Image.open(file_path) as img:resolution = f"{img.width}x{img.height}"except Exception as e:resolution = "N/A"ws.append([file, file_path, creation_date, size, resolution])save_path = os.path.join(dir_path, 'image_info.xlsx')wb.save(save_path)wx.MessageBox(f'Excel file created at {save_path}', 'Success', wx.OK | wx.ICON_INFORMATION)if __name__ == '__main__':app = wx.App(False)frame = ImageInfoApp(None, title='Image Info to Excel')app.MainLoop()
代码解释
  1. 导入模块

    • wx:用于创建图形用户界面。
    • os:用于文件和目录操作。
    • openpyxl:用于创建和操作 Excel 文件。
    • PIL(Pillow):用于处理图像文件,获取其分辨率。
    • datetime:用于处理文件的创建日期。
  2. 创建 GUI 界面

    • ImageInfoApp 类继承自 wx.Frame,是我们的主窗口。
    • 界面包含一个目录选择器(wx.DirPickerCtrl)和一个按钮(wx.Button),用于选择目录和生成 Excel 文件。
    • 按钮绑定了 on_generate_excel 方法,该方法在用户点击按钮时执行。
  3. 生成 Excel 文件

    • 用户选择目录后,on_generate_excel 方法会遍历该目录及其子目录中的所有图像文件。
    • 获取每个图像文件的名称、路径、创建日期、大小和分辨率,并将这些信息写入到 Excel 文件中。
    • 最终生成的 Excel 文件保存在用户选择的目录中。

运行程序

将上述代码保存为一个 Python 文件(例如 image_info_to_excel.py),然后在终端或命令提示符中运行:

python image_info_to_excel.py

此时会弹出一个窗口,用户可以选择一个文件夹,并点击按钮生成包含图片信息的 Excel 文件。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

总结

通过这篇博客,我们学习了如何使用 wxPython 创建一个 GUI 应用,从文件夹中提取图片信息并将其导入到 Excel 表格中。这种方法不仅可以用于图片文件,还可以根据需要扩展到其他类型的文件数据提取和整理。如果您有任何问题或建议,欢迎在评论区留言。

这篇关于Python 将文件夹中的图片信息导入到 Excel 的表格的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1000876

相关文章

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四