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

相关文章

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Python Websockets库的使用指南

《PythonWebsockets库的使用指南》pythonwebsockets库是一个用于创建WebSocket服务器和客户端的Python库,它提供了一种简单的方式来实现实时通信,支持异步和同步... 目录一、WebSocket 简介二、python 的 websockets 库安装三、完整代码示例1.

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意