使用Python 打造多格式文件预览工具 — 图、PDF、Word、Excel 一站式查看
在日常办公或文件管理场景中,我们经常面临这样的问题:在一个文件夹中短时间内产生了大量不同类型的文件(如图片、PDF、Word、Excel),我们需要快速浏览和筛选这些文件的内容,却不希望一个个打开它们。有没有办法将这些文件集中预览、筛选和操作?
本文将带你打造一个基于 wxPython
的多格式文件浏览与预览工具,支持文件夹选择、最近一天文件筛选、图文文档预览、页码控制、压缩打包、文件复制等多项实用功能。
C:\pythoncode\new\ViewFileAndZipAndCopy.py
一、功能概览
该工具具备以下核心功能:
-
文件夹选择:通过 GUI 选择任意文件夹。
-
筛选最新文件:自动列出过去 24 小时内修改或创建的文件。
-
多类型预览支持:
- 图片(JPG/PNG/BMP/GIF)
- PDF(支持翻页)
- Word(.docx,以 HTML 模式显示)
- Excel(显示为列表控件)
-
文件复选操作:支持对文件进行勾选,便于批量操作。
-
文件压缩与复制:将勾选文件打包为 ZIP,或复制到目标文件夹。
-
分页预览控制:针对 PDF,提供上一页/下一页导航按钮。
二、应用场景
这个工具适用于以下典型场景:
- 企业文档审核:在文档提交截止前查看最近更新的项目文档。
- 技术支持或维护日志审核:快速翻阅技术支持部门刚上传的截图、报告、系统日志。
- 内容策划与编辑:在多媒体内容创作场景中,快速预览当天采集的素材。
- 文件归档前审查:在正式归档前核查文档内容和格式。
三、界面布局与技术实现
1. 总体结构:SplitterWindow 分割主界面
self.splitter = wx.SplitterWindow(self)
self.left_panel = wx.Panel(self.splitter)
self.right_panel = wx.Panel(self.splitter)
self.splitter.SplitVertically(self.left_panel, self.right_panel)
- 左侧用于显示文件列表、控制按钮;
- 右侧用于显示预览内容和翻页控件。
2. 文件筛选逻辑:列出最近 24 小时文件
one_day_ago = time.time() - (24 * 60 * 60)
for root, dirs, filenames in os.walk(folder_path):for filename in filenames:file_path = os.path.join(root, filename)if os.path.getmtime(file_path) >= one_day_ago:files.append(file_path)
这段代码遍历目标文件夹及其子目录,只保留“修改时间在过去 24 小时之内”的文件。
3. 多格式文件预览实现
图片预览
img = wx.Image(file_path, wx.BITMAP_TYPE_ANY)
img = img.Scale(preview_size.width, preview_size.height)
self.image_preview.SetBitmap(wx.Bitmap(img))
使用 wx.Image
载入并缩放图像,然后通过 wx.StaticBitmap
显示。
PDF 预览(支持翻页)
self.doc = fitz.open(file_path)
page = self.doc[self.current_page]
pix = page.get_pixmap(matrix=fitz.Matrix(1.5, 1.5))
img = wx.Image(pix.width, pix.height, pix.samples)
借助 PyMuPDF
(即 fitz
),将 PDF 页渲染成图像,再通过 wxWidgets 展示。
Word 预览
doc = docx.Document(file_path)
html = "<html><body>" + "".join(f"<p>{para.text}</p>" for para in doc.paragraphs) + "</body></html>"
self.doc_preview.SetPage(html)
Word 内容解析为 HTML,再使用 wx.html2.WebView
来显示。
Excel 预览
df = pd.read_excel(file_path)
for i, col in enumerate(df.columns):self.excel_preview.InsertColumn(i, str(col))
for index, row in df.iterrows():self.excel_preview.InsertItem(index, str(row[0]))
利用 pandas
读取表格并填入 wx.ListCtrl
控件中。
4. 文件压缩与复制按钮(待补充功能)
self.zip_button = wx.Button(button_panel, label="压缩选择文件")
self.copy_button = wx.Button(button_panel, label="复制选择文件")
目前绑定事件函数尚未实现(代码略去),后续可以通过 zipfile.ZipFile
实现 ZIP 操作,使用 shutil.copy
进行文件复制。
运行结果
在这里插入图片描述
四、总结
如果你经常处理多种类型的文档,或者你是一位内容审核员、资料整理者,那么这个工具将大幅提升你的工作效率。