PySimpleGUI界面读取PDF转换Excel

PySimpleGUI 是一个用于创建图形用户界面的 Python 库,而 PDF 文件和 Excel 文件是两种不同的数据格式。要将 PDF 文件转换为 Excel 文件,你需要使用额外的库,如 pdf2excel

下面是一个示例流程,展示了如何使用 PySimpleGUI 创建一个界面,以便用户选择 PDF 文件并读取其中的数据,然后将其导入 Excel 文件:

  1. 安装所需的库
复制代码

bash复制代码

|---|----------------------------------------------|
| | pip install PySimpleGUI pdf2excel openpyxl |

  1. 使用 PySimpleGUI 创建界面
复制代码

python复制代码

|---|-----------------------------------------------------------------------------------------------------------------|
| | import PySimpleGUI as sg |
| | |
| | # 定义列和行布局 |
| | layout = [[sg.Column([[sg.Text("选择 PDF 文件:")], [sg.In(key='-IN-')]], pad=(0,0))], |
| | [sg.Text("选择输出 Excel 文件:")], |
| | [sg.In(key='-OUT-')], |
| | [sg.Column([[sg.Text("开始转换")], [sg.FileBrowse(file_types=(("PDF files", "*.pdf"), ("All files", "*.*")))]])] |
| | |
| | # 创建窗口布局 |
| | window = sg.Window("PDF to Excel Converter", layout, margins=(0,0), finalize=True) |
| | |
| | # 事件循环 |
| | while True: |
| | event, values = window.read() |
| | if event == sg.WINDOW_CLOSED: |
| | break |
| | elif event == "-IN-": |
| | input_file = values['-IN-'] |
| | elif event == "-OUT-": |
| | output_file = values['-OUT-'] |
| | elif event == "FileSelected": |
| | # 使用 pdf2excel 进行转换 |
| | pdf2excel(input_file, output_file) |
| | sg.popup_error("转换完成!") |

  1. 使用 pdf2excel 进行转换 :请注意,pdf2excel 是一个独立的库,它负责实际的 PDF 到 Excel 的转换。你可能需要自己编写这部分逻辑,或者找到一个合适的库。如果 pdf2excel 不满足你的需求,你可能需要查找其他库或工具来完成这个任务。

  2. 保存 Excel 文件 :在上述代码中,我们使用了 openpyxl 来保存 Excel 文件。你可以使用以下代码作为参考:

复制代码

python复制代码

|---|-------------------------------------------------|
| | from openpyxl import Workbook |
| | from openpyxl.utils import get_column_letter |
| | |
| | def save_to_excel(data, filename): |
| | wb = Workbook() |
| | ws = wb.active |
| | for r in data: |
| | ws.append(r) |
| | wb.save(filename) |

在完整的程序中,你需要根据实际的 PDF 文件内容和格式来调整这个函数,使其能够正确地将数据保存到 Excel 文件中。

  1. 处理异常和错误 :在实际应用中,你应该添加异常处理逻辑,以便在转换过程中出现错误时给出清晰的错误消息。这可能涉及到捕获 pdf2excel 库可能抛出的任何异常。

  2. 关闭窗口 :在程序结束时,确保关闭 PySimpleGUI 窗口。你可以在 sg.Windowclose 方法中添加适当的逻辑来处理这一点。

  3. 测试和调试:在实际部署之前,确保对程序进行彻底的测试和调试,以确保其按预期工作。

相关推荐
John_ToDebug2 分钟前
浏览器扩展延迟加载优化实战:如何让浏览器启动速度提升50%
c++·chrome·windows
kyriewen113 小时前
给浏览器画个圈:CSS contain 如何让页面从“卡成PPT”变“丝滑如德芙”
开发语言·前端·javascript·css·chrome·typescript·ecmascript
维度攻城狮4 小时前
Docker-Ubuntu安装并启动Chrome浏览器
chrome·ubuntu·docker·安装
开开心心就好7 小时前
免费自媒体多功能工具箱,图片音视频处理
人工智能·pdf·ocr·excel·音视频·语音识别·媒体
halfpast310 小时前
excel查看ni tdm格式文件
excel·ni·tdm文件
JavaPub-rodert12 小时前
Codex GPT-5.4 使用教程(命令大全版)
前端·chrome·gpt·codex
酉鬼女又兒13 小时前
零基础快速入门前端JavaScript Array 常用方法详解与实战(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·javascript·chrome·蓝桥杯
John_ToDebug13 小时前
深入解析 Chrome 渲染进程合并优化策略:以 desktop_view 为例
c++·chrome·windows
SuperEugene14 小时前
前端实战:Excel 导入导出规范(命名 + 校验 + 错误处理 + 统一交互)|API 与异步请求规范篇
前端·javascript·vue.js·前端框架·excel
优化控制仿真模型14 小时前
【英二】考研英语二历年真题及答案解析PDF电子版(1980-2025年)
经验分享·考研·pdf