当前位置: 首页 > news >正文

各网站的风格及特点网站移动转换

各网站的风格及特点,网站移动转换,全网推广费用,临沭县住房和城乡建设局网站引言: 处理大量PDF文档的文本提取任务可能是一项繁琐的工作。本文将介绍一个使用Python编写的工具,可通过简单的操作一键提取大量PDF文档中的文本内容,极大地提高工作效率。 import wx import pathlib import fitzclass PDFExtractor(wx.Fr…

引言:

处理大量PDF文档的文本提取任务可能是一项繁琐的工作。本文将介绍一个使用Python编写的工具,可通过简单的操作一键提取大量PDF文档中的文本内容,极大地提高工作效率。

import wx
import pathlib
import fitzclass PDFExtractor(wx.Frame):def __init__(self, parent, title):super(PDFExtractor, self).__init__(parent, title=title, size=(400, 200))panel = wx.Panel(self)vbox = wx.BoxSizer(wx.VERTICAL)self.file_picker = wx.FilePickerCtrl(panel, style=wx.FLP_DEFAULT_STYLE | wx.FLP_USE_TEXTCTRL)self.save_picker = wx.DirPickerCtrl(panel, style=wx.DIRP_DEFAULT_STYLE | wx.DIRP_USE_TEXTCTRL)self.extract_button = wx.Button(panel, label="提取")self.extract_button.Bind(wx.EVT_BUTTON, self.on_extract)vbox.Add(wx.StaticText(panel, label="选择PDF文件:"), 0, wx.ALL | wx.EXPAND, 5)vbox.Add(self.file_picker, 0, wx.ALL | wx.EXPAND, 5)vbox.Add(wx.StaticText(panel, label="选择输出路径:"), 0, wx.ALL | wx.EXPAND, 5)vbox.Add(self.save_picker, 0, wx.ALL | wx.EXPAND, 5)vbox.Add(self.extract_button, 0, wx.ALL | wx.CENTER, 5)panel.SetSizer(vbox)def on_extract(self, event):pdf_path = self.file_picker.GetPath()save_path = self.save_picker.GetPath()if pdf_path and save_path:progress_dialog = wx.ProgressDialog("提取进度", "正在提取...", maximum=100, parent=self)try:with fitz.open(pdf_path) as doc:total_pages = len(doc)progress = 0for index, page in enumerate(doc):text = page.get_text()output_file = pathlib.Path(save_path) / f"page_{index + 1}.txt"output_file.write_text(text, encoding="utf-8")progress = int((index + 1) / total_pages * 100)progress_dialog.Update(progress, f"正在提取第 {index + 1} 页 / 共 {total_pages} 页")progress_dialog.Update(100, "提取完成!")wx.MessageBox("提取完成!", "成功", wx.OK | wx.ICON_INFORMATION)except Exception as e:wx.MessageBox(str(e), "错误", wx.OK | wx.ICON_ERROR)finally:progress_dialog.Destroy()else:wx.MessageBox("请选择PDF文件和输出路径!", "错误", wx.OK | wx.ICON_ERROR)def main():app = wx.App()frame = PDFExtractor(None, "PDF提取器")frame.Show()app.MainLoop()if __name__ == '__main__':main()

在这个示例中,我们创建了一个wx.ProgressDialog对象,用于显示提取进度。在提取每一页的文本时,我们使用enumerate函数获取当前页的索引,并根据总页数计算提取进度的百分比。然后,我们使用progress_dialog.Update方法更新进度条的进度和显示的文本。

请注意,由于提取过程可能需要一些时间,所以我们使用进度条对话框来显示进度并阻止用户的交互。在提取完成后,进度条对话框会自动关闭。

其中:

1)文档选择: 

      self.file_picker = wx.FilePickerCtrl(panel, style=wx.FLP_DEFAULT_STYLE | wx.FLP_USE_TEXTCTRL)

2、文件夹选择:     

   self.save_picker = wx.DirPickerCtrl(panel, style=wx.DIRP_DEFAULT_STYLE | wx.DIRP_USE_TEXTCTRL)

3、进度显示:

progress = int((index + 1) / total_pages * 100)progress_dialog.Update(progress, f"正在提取第 {index + 1} 页 / 共 {total_pages} 页")progress_dialog.Update(100, "提取完成!")

4、最重要的:获得pdf中的文本:

with fitz.open(pdf_path) as doc:total_pages = len(doc)progress = 0for index, page in enumerate(doc):text = page.get_text()output_file = pathlib.Path(save_path) / f"page_{index + 1}.txt"output_file.write_text(text, encoding="utf-8")

结果如下:

  

http://www.yayakq.cn/news/627192/

相关文章:

  • 代做网站的公司有哪些设计网站的结构时
  • wordpress 企业站点开发公司终止函内容
  • 潍坊市建设工程质量安全监督站网站网站专题欣赏
  • 如何自做自己的网站织梦网站怎么做伪静态
  • 网站有版权吗商城入口
  • 网站建设亿玛酷技术展示型建站模板平台
  • 网站建设开发教程c2m模式的电商平台有哪些
  • 旅游网站建设策划书网页设计美化教程
  • 建设银行jo 办网站用卡seo流量
  • 简单的个人主页网站制作html绍兴柯桥建设局网站
  • 福州福清网站建设网站开发项目私活
  • 企业网站前端建设焊工培训技术学校
  • 狮山网站开发黑龙江建设人力资源网站
  • 怎样做网站卖手机号深圳购物网站建设公司
  • 怎么用html做图片展示网站天门网站网站建设
  • 住房城乡建设部门户网站钦州建设银行社招聘网站
  • 购物分享网站怎么做的漂亮产品网站
  • 服装网站栏目wordpress 留言汉化
  • 推广型网站建设软件团购网站营销方案
  • 深圳企业网站制作设计方案上海突然传来噩耗
  • 设计接单子网站徐州网站营销
  • 广州公司网站建设设计顾拼多多推广联盟
  • wordpress模板如何修改字体南宁白帽seo技术
  • asp网站 证书wordpress代码逻辑
  • 做电商网站费用平面设计是做什么的工作
  • 网站建设公司源码 asp电子商务网站建设需要的语言
  • 郑州网站推广汉狮网络三亚
  • 帮公司做网站怎么找网站开发适合女生不
  • 沈阳建设网站服务公司做电影网站能赚钱吗
  • 宁波网站建设果核360街景地图怎么看