百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

用DeepSeek+Trae 自己写PDF表格转为EXCEL表格

itomcoil 2025-04-30 17:34 17 浏览


如何将下面PDF表格转为EXCEL能更好统计



在TRAE 提问:

新建窗口-选择文件夹-




写一个PDF转excel 电脑程序:样式不变,界面 有选择文件,有输出文件,显示进度及页码,开始,暂停,退出,实现所有功能写出全部代码


DEEPSEEK 进行深度思考:

好的,我将帮助您创建一个PDF转Excel的桌面程序。首先需要设计GUI界面包含文件选择、输出路径、进度显示等功能。核心部分需要使用Python的PyMuPDF或pdfplumber库解析PDF内容,用openpyxl生成Excel文件。建议采用Tkinter实现界面,通过多线程处理转换任务防止界面卡顿,并添加暂停/恢复逻辑。将创建包含GUI布局、PDF解析逻辑和Excel格式处理三个核心模块。

代码:import tkinter as tk

from tkinter import ttk, filedialog

import threading

import fitz # PyMuPDF

import openpyxl

from queue import Queue


class PDFConverterApp:

def __init__(self, master):

self.master = master

master.title("PDF转Excel工具")

# 文件选择部分

self.input_frame = ttk.Frame(master)

self.input_frame.pack(pady=10, fill='x')

self.input_btn = ttk.Button(self.input_frame, text="选择PDF文件", command=self.select_pdf)

self.input_btn.pack(side='left')

self.input_label = ttk.Label(self.input_frame, text="未选择文件")

self.input_label.pack(side='left', padx=10)

# 输出路径部分

self.output_frame = ttk.Frame(master)

self.output_frame.pack(pady=10, fill='x')

self.output_btn = ttk.Button(self.output_frame, text="选择输出路径", command=self.select_output)

self.output_btn.pack(side='left')

self.output_label = ttk.Label(self.output_frame, text="未选择路径")

self.output_label.pack(side='left', padx=10)

# 进度条

self.progress = ttk.Progressbar(master, orient='horizontal', length=200, mode='determinate')

self.progress.pack(pady=10)

# 控制按钮

self.btn_frame = ttk.Frame(master)

self.btn_frame.pack(pady=10)

self.start_btn = ttk.Button(self.btn_frame, text="开始转换", command=self.start_conversion)

self.start_btn.pack(side='left', padx=5)

self.pause_btn = ttk.Button(self.btn_frame, text="暂停", state='disabled', command=self.toggle_pause)

self.pause_btn.pack(side='left', padx=5)

self.exit_btn = ttk.Button(self.btn_frame, text="退出", command=master.quit)

self.exit_btn.pack(side='left', padx=5)

# 状态变量

self.is_paused = False

self.current_page = 0

self.conversion_thread = None

self.queue = Queue()

def select_pdf(self):

file_path =
filedialog.askopenfilename(filetypes=[("PDF文件", "*.pdf")])

if file_path:

self.input_label.config(text=file_path)

def select_output(self):

output_path = filedialog.askdirectory()

if output_path:

self.output_label.config(text=output_path)

def start_conversion(self):

# 验证输入输出路径

# 启动转换线程

self.conversion_thread = threading.Thread(target=self.convert_pdf)

self.conversion_thread.start()

self.start_btn.config(state='disabled')

self.pause_btn.config(state='normal')

def toggle_pause(self):

self.is_paused = not self.is_paused

self.pause_btn.config(text="继续" if self.is_paused else "暂停")

def convert_pdf(self):

try:

pdf_path = self.input_label.cget("text")

output_dir = self.output_label.cget("text")

if not pdf_path or not output_dir:

self.queue.put(('error', '请先选择PDF文件和输出路径'))

return


doc = fitz.open(pdf_path)

total_pages = len(doc)

wb = openpyxl.Workbook()

ws = wb.active

for page_num in range(total_pages):

while self.is_paused:

pass # 暂停状态循环等待

page = doc.load_page(page_num)

text = page.get_text()

# 按行写入Excel

for row_num, line in enumerate(text.split('\n'), 1):

ws.cell(row=row_num, column=1, value=line)

# 更新进度

self.current_page = page_num + 1

progress = (self.current_page / total_pages) * 100

self.queue.put(('progress', (progress, f'正在转换第{self.current_page}页')))

output_path = f"{output_dir}/output.xlsx"

wb.save(output_path)

self.queue.put(('complete', f'转换完成!文件已保存至:{output_path}'))

except Exception as e:

self.queue.put(('error', f'转换失败:{str(e)}'))

finally:

self.start_btn.config(state='normal')

self.pause_btn.config(state='disabled')


if __name__ == "__main__":

root = tk.Tk()

app = PDFConverterApp(root)

root.mainloop()

提示需要的安装库:pip install PyMuPDF openpyxl 在命令行执行


执行PYTHON+文件名 命令运行



测试是否达到完成要求?


追加功能显示转化代码

如果有语法错误,自动修改错误



总结一下:在写软件要求时,第一步提问尽量要全面,要修改的话,容易逻辑上出错

可以让DEEPSEEK写出软件设计方案

相关推荐

selenium(WEB自动化工具)

定义解释Selenium是一个用于Web应用程序测试的工具。Selenium测试直接运行在浏览器中,就像真正的用户在操作一样。支持的浏览器包括IE(7,8,9,10,11),MozillaF...

开发利器丨如何使用ELK设计微服务中的日志收集方案?

【摘要】微服务各个组件的相关实践会涉及到工具,本文将会介绍微服务日常开发的一些利器,这些工具帮助我们构建更加健壮的微服务系统,并帮助排查解决微服务系统中的问题与性能瓶颈等。我们将重点介绍微服务架构中...

高并发系统设计:应对每秒数万QPS的架构策略

当面试官问及"如何应对每秒几万QPS(QueriesPerSecond)"时,大概率是想知道你对高并发系统设计的理解有多少。本文将深入探讨从基础设施到应用层面的解决方案。01、理解...

2025 年每个 JavaScript 开发者都应该了解的功能

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发。1.Iteratorhelpers开发者...

JavaScript Array 对象

Array对象Array对象用于在变量中存储多个值:varcars=["Saab","Volvo","BMW"];第一个数组元素的索引值为0,第二个索引值为1,以此类推。更多有...

Gemini 2.5编程全球霸榜,谷歌重回AI王座,神秘模型曝光,奥特曼迎战

刚刚,Gemini2.5Pro编程登顶,6美元性价比碾压Claude3.7Sonnet。不仅如此,谷歌还暗藏着更强的编程模型Dragontail,这次是要彻底翻盘了。谷歌,彻底打了一场漂亮的翻...

动力节点最新JavaScript教程(高级篇),深入学习JavaScript

JavaScript是一种运行在浏览器中的解释型编程语言,它的解释器被称为JavaScript引擎,是浏览器的一部分,JavaScript广泛用于浏览器客户端编程,通常JavaScript脚本是通过嵌...

一文看懂Kiro,其 Spec工作流秒杀Cursor,可移植至Claude Code

当Cursor的“即兴编程”开始拖累项目质量,AWS新晋IDEKiro以Spec工作流打出“先规范后编码”的系统工程思维:需求-设计-任务三件套一次生成,文档与代码同步落地,复杂项目不...

「晚安·好梦」努力只能及格,拼命才能优秀

欢迎光临,浏览之前点击上面的音乐放松一下心情吧!喜欢的话给小编一个关注呀!Effortscanonlypass,anddesperatelycanbeexcellent.努力只能及格...

JavaScript 中 some 与 every 方法的区别是什么?

大家好,很高兴又见面了,我是姜茶的编程笔记,我们一起学习前端相关领域技术,共同进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力在JavaScript中,Array.protot...

10个高效的Python爬虫框架,你用过几个?

小型爬虫需求,requests库+bs4库就能解决;大型爬虫数据,尤其涉及异步抓取、内容管理及后续扩展等功能时,就需要用到爬虫框架了。下面介绍了10个爬虫框架,大家可以学习使用!1.Scrapysc...

12个高效的Python爬虫框架,你用过几个?

实现爬虫技术的编程环境有很多种,Java、Python、C++等都可以用来爬虫。但很多人选择Python来写爬虫,为什么呢?因为Python确实很适合做爬虫,丰富的第三方库十分强大,简单几行代码便可实...

pip3 install pyspider报错问题解决

运行如下命令报错:>>>pip3installpyspider观察上面的报错问题,需要安装pycurl。是到这个网址:http://www.lfd.uci.edu/~gohlke...

PySpider框架的使用

PysiderPysider是一个国人用Python编写的、带有强大的WebUI的网络爬虫系统,它支持多种数据库、任务监控、项目管理、结果查看、URL去重等强大的功能。安装pip3inst...

「机器学习」神经网络的激活函数、并通过python实现激活函数

神经网络的激活函数、并通过python实现whatis激活函数感知机的网络结构如下:左图中,偏置b没有被画出来,如果要表示出b,可以像右图那样做。用数学式来表示感知机:上面这个数学式子可以被改写:...