使用Python 打造多格式文件预览工具 — 图、PDF、Word、Excel 一站式查看

在日常办公或文件管理场景中,我们经常面临这样的问题:在一个文件夹中短时间内产生了大量不同类型的文件(如图片、PDF、Word、Excel),我们需要快速浏览和筛选这些文件的内容,却不希望一个个打开它们。有没有办法将这些文件集中预览、筛选和操作?

本文将带你打造一个基于 wxPython 的多格式文件浏览与预览工具,支持文件夹选择、最近一天文件筛选、图文文档预览、页码控制、压缩打包、文件复制等多项实用功能。

C:\pythoncode\new\ViewFileAndZipAndCopy.py

一、功能概览

该工具具备以下核心功能:

  1. 文件夹选择:通过 GUI 选择任意文件夹。

  2. 筛选最新文件:自动列出过去 24 小时内修改或创建的文件。

  3. 多类型预览支持

    • 图片(JPG/PNG/BMP/GIF)
    • PDF(支持翻页)
    • Word(.docx,以 HTML 模式显示)
    • Excel(显示为列表控件)
  4. 文件复选操作:支持对文件进行勾选,便于批量操作。

  5. 文件压缩与复制:将勾选文件打包为 ZIP,或复制到目标文件夹。

  6. 分页预览控制:针对 PDF,提供上一页/下一页导航按钮。


二、应用场景

这个工具适用于以下典型场景:

  • 企业文档审核:在文档提交截止前查看最近更新的项目文档。
  • 技术支持或维护日志审核:快速翻阅技术支持部门刚上传的截图、报告、系统日志。
  • 内容策划与编辑:在多媒体内容创作场景中,快速预览当天采集的素材。
  • 文件归档前审查:在正式归档前核查文档内容和格式。

三、界面布局与技术实现

1. 总体结构:SplitterWindow 分割主界面

python 复制代码
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 小时文件

python 复制代码
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. 多格式文件预览实现

图片预览
python 复制代码
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 预览(支持翻页)
python 复制代码
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 预览
python 复制代码
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 预览
python 复制代码
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. 文件压缩与复制按钮(待补充功能)

python 复制代码
self.zip_button = wx.Button(button_panel, label="压缩选择文件")
self.copy_button = wx.Button(button_panel, label="复制选择文件")

目前绑定事件函数尚未实现(代码略去),后续可以通过 zipfile.ZipFile 实现 ZIP 操作,使用 shutil.copy 进行文件复制。


运行结果

在这里插入图片描述

四、总结

如果你经常处理多种类型的文档,或者你是一位内容审核员、资料整理者,那么这个工具将大幅提升你的工作效率。

相关推荐
计算机软件程序设计2 小时前
基于Python的二手车价格数据分析与预测系统的设计与实现
开发语言·python·数据分析·预测系统
mortimer3 小时前
Traceback 模块:`format_exc` 和 `format_exception` 傻傻分不清
python
Cherry Zack3 小时前
了解Django模型,从基础到实战
python·学习·django
qq7422349844 小时前
语音识别:PyAudio、SoundDevice、Vosk、openai-whisper、Argos-Translate、FunASR(Python)
python·whisper·语音识别
曾经的三心草4 小时前
OpenCV2-图像基本操作-阈值与平滑处理-形态学-梯度运算
python·opencv
xiangzhihong84 小时前
Spring Boot实现文字转语音功能
开发语言·python
少陽君4 小时前
两个表格(Excel/CSV)字段不完全一致,要合并在一起
excel
Excel_easy5 小时前
Excel文件瘦身指南:快速瘦身,告别卡顿-Excel易用宝
excel
天才测试猿5 小时前
postman使用总结
自动化测试·软件测试·python·测试工具·测试用例·接口测试·postman
可触的未来,发芽的智生5 小时前
新奇特:神经网络烘焙坊(下),万能配方的甜蜜奥义
人工智能·python·神经网络·算法·架构