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

市场调研公司seo工具有哪些

市场调研公司,seo工具有哪些,blog启示录——wordpress博客建设与经营(配光盘),做的好点的外贸网站有哪些在本篇博客中,我们将探讨如何使用wxPython和PyMuPDF库创建一个简单的Bokeh应用程序,用于选择PDF文件并提取指定页面的内容,并将提取的内容显示在文本框中。 C:\pythoncode\new\pdfgetcontent.py 准备工作 首先,确保你已经安装了…

在本篇博客中,我们将探讨如何使用wxPython和PyMuPDF库创建一个简单的Bokeh应用程序,用于选择PDF文件并提取指定页面的内容,并将提取的内容显示在文本框中。
C:\pythoncode\new\pdfgetcontent.py
在这里插入图片描述

准备工作

首先,确保你已经安装了以下库:

  • wxPython:用于创建桌面应用程序界面。
  • PyMuPDF:用于处理PDF文件和提取页面内容。

你可以使用以下命令来安装这些库:

pip install wxPython pymupdf 

创建应用程序界面

我们将使用wxPython来创建应用程序的图形界面。在应用程序窗口中,我们将添加一个选择按钮,一个页码输入框,一个提取按钮和一个文本框用于显示提取的内容。

def __init__(self):super().__init__(None, title="提取PDF页面内容", size=(400, 300))panel = wx.Panel(self)vbox = wx.BoxSizer(wx.VERTICAL)select_button = wx.Button(panel, label="选择PDF文件")select_button.Bind(wx.EVT_BUTTON, self.on_select_pdf)vbox.Add(select_button, proportion=0, flag=wx.ALIGN_CENTER | wx.ALL, border=10)page_label = wx.StaticText(panel, label="页码:")vbox.Add(page_label, proportion=0, flag=wx.LEFT, border=10)self.page_input = wx.TextCtrl(panel)vbox.Add(self.page_input, proportion=0, flag=wx.EXPAND | wx.ALL, border=10)extract_button = wx.Button(panel, label="提取内容")extract_button.Bind(wx.EVT_BUTTON, self.on_extract_content)vbox.Add(extract_button, proportion=0, flag=wx.ALIGN_CENTER | wx.ALL, border=10)content_label = wx.StaticText(panel, label="内容:")vbox.Add(content_label, proportion=0, flag=wx.LEFT, border=10)self.content_text = wx.TextCtrl(panel, style=wx.TE_MULTILINE | wx.TE_READONLY)vbox.Add(self.content_text, proportion=1, flag=wx.EXPAND | wx.ALL, border=10)panel.SetSizer(vbox)def on_select_pdf(self, event):dialog = wx.FileDialog(self, message="选择PDF文件", wildcard="PDF files (*.pdf)|*.pdf", style=wx.FD_OPEN)if dialog.ShowModal() == wx.ID_OK:self.pdf_path = dialog.GetPath()dialog.Destroy()

在上述代码中,我们创建了一个名为PDFContentExtractor的类,继承自wx.Frame。在该类中,我们使用Bokeh创建了一个包含选择按钮、页码输入框、提取按钮和内容文本框的布局。我们为选择按钮和提取按钮绑定了相应的事件处理方法。

处理PDF文件选择和内容提取

我们使用wxPython的文件对话框来选择PDF文件,并使用PyMuPDF库来打开和处理PDF文件。当用户选择PDF文件并点击提取按钮时,我们将提取指定页码的内容,并将其显示在内容文本框中。

import wx
import fitzclass MyFrame(wx.Frame):def __init__(self):super().__init__(None, title="提取PDF页面内容", size=(400, 300))panel = wx.Panel(self)vbox = wx.BoxSizer(wx.VERTICAL)select_button = wx.Button(panel, label="选择PDF文件")select_button.Bind(wx.EVT_BUTTON, self.on_select_pdf)vbox.Add(select_button, proportion=0, flag=wx.ALIGN_CENTER | wx.ALL, border=10)page_label = wx.StaticText(panel, label="页码:")vbox.Add(page_label, proportion=0, flag=wx.LEFT, border=10)self.page_input = wx.TextCtrl(panel)vbox.Add(self.page_input, proportion=0, flag=wx.EXPAND | wx.ALL, border=10)extract_button = wx.Button(panel, label="提取内容")extract_button.Bind(wx.EVT_BUTTON, self.on_extract_content)vbox.Add(extract_button, proportion=0, flag=wx.ALIGN_CENTER | wx.ALL, border=10)content_label = wx.StaticText(panel, label="内容:")vbox.Add(content_label, proportion=0, flag=wx.LEFT, border=10)self.content_text = wx.TextCtrl(panel, style=wx.TE_MULTILINE | wx.TE_READONLY)vbox.Add(self.content_text, proportion=1, flag=wx.EXPAND | wx.ALL, border=10)panel.SetSizer(vbox)def on_select_pdf(self, event):dialog = wx.FileDialog(self, message="选择PDF文件", wildcard="PDF files (*.pdf)|*.pdf", style=wx.FD_OPEN)if dialog.ShowModal() == wx.ID_OK:self.pdf_path = dialog.GetPath()dialog.Destroy()def on_extract_content(self, event):page_num = int(self.page_input.GetValue())self.extract_page_content(page_num)def extract_page_content(self, page_num):doc = fitz.open(self.pdf_path)if page_num < 1 or page_num > doc.page_count:wx.MessageBox("无效的页码!", "错误", wx.OK | wx.ICON_ERROR)returnpage = doc.load_page(page_num - 1)text = page.get_text()self.content_text.SetValue(text)doc.close()if __name__ == '__main__':app = wx.App()frame = MyFrame()frame.Show()app.MainLoop()# ...class PDFContentExtractor(wx.Frame):# ...def on_select_pdf(self):dialog = wx.FileDialog(self, message="选择PDF文件", wildcard="PDF files (*.pdf)|*.pdf", style=wx.FD_OPEN)if dialog.ShowModal() == wx.ID_OK:self.pdf_path = dialog.GetPath()dialog.Destroy()def on_extract_content(self):page_num = int(self.page_input.value)self.extract_page_content(page_num)def extract_page_content(self, page_num):doc = fitz.open(self.pdf_path)if page_num < 1 or page_num > doc.page_count:self.content_text.text = "无效的页码!"returnpage = doc.load_page(page_num - 1)text = page.get_text()self.content_text.text = textdoc.close()# ...

在上述代码中,我们使用wx.FileDialog对话框来选择PDF文件,并将选择的文件路径存储在self.pdf_path变量中。

on_extract_content方法中,我们获取输入框中的页码,并调用extract_page_content方法来提取指定页码的内容。

extract_page_content方法中,我们使用PyMuPDF打开并读取PDF文件。然后,我们通过doc.load_page方法加载指定页码的页面,并使用get_text方法获取该页的文本内容。最后,我们将提取的内容设置到文本框content_text中。

运行应用程序

if __name__ == '__main__':app = wx.App()frame = PDFContentExtractor()frame.Show()app.MainLoop()

在上述代码中,我们创建了一个wx.App实例,并实例化了PDFContentExtractor类。然后,我们显示应用程序窗口,并通过调用app.MainLoop()来启动应用程序的事件循环。

结论

通过本篇博客,我们学习了如何使用wxPython和PyMuPDF创建用于选择PDF文件并提取指定页面的内容。我们还了解了如何使用Bokeh来创建交互式应用程序界面,并通过事件处理方法来处理用户的选择和操作。


文章转载自:
http://dinncoprimogeniture.stkw.cn
http://dinncoearbender.stkw.cn
http://dinncoinadequacy.stkw.cn
http://dinncounshaded.stkw.cn
http://dinncocrosstie.stkw.cn
http://dinncodecimalization.stkw.cn
http://dinncoelate.stkw.cn
http://dinncohae.stkw.cn
http://dinncomudslinging.stkw.cn
http://dinncodrawplate.stkw.cn
http://dinncohutung.stkw.cn
http://dinncoinnovative.stkw.cn
http://dinncogamb.stkw.cn
http://dinncobeagle.stkw.cn
http://dinncoclash.stkw.cn
http://dinncosouthwester.stkw.cn
http://dinncoclothespin.stkw.cn
http://dinncoheracles.stkw.cn
http://dinncoweevil.stkw.cn
http://dinncodoxastic.stkw.cn
http://dinncocustomization.stkw.cn
http://dinncoarduously.stkw.cn
http://dinncocachexia.stkw.cn
http://dinncobewildering.stkw.cn
http://dinncoautoincrement.stkw.cn
http://dinncopolysemous.stkw.cn
http://dinncokeck.stkw.cn
http://dinncoelamitish.stkw.cn
http://dinncogilolo.stkw.cn
http://dinncounific.stkw.cn
http://dinncopandybat.stkw.cn
http://dinnconectary.stkw.cn
http://dinncosilkaline.stkw.cn
http://dinncoiguanodon.stkw.cn
http://dinncofastball.stkw.cn
http://dinncostatement.stkw.cn
http://dinncojingoistic.stkw.cn
http://dinncothrough.stkw.cn
http://dinncouneventfully.stkw.cn
http://dinncovoidance.stkw.cn
http://dinncoserialism.stkw.cn
http://dinncocaddy.stkw.cn
http://dinncopopinjay.stkw.cn
http://dinncotrioxid.stkw.cn
http://dinncoairmanship.stkw.cn
http://dinncopusillanimously.stkw.cn
http://dinncocongenial.stkw.cn
http://dinncosubminiaturize.stkw.cn
http://dinncobode.stkw.cn
http://dinncorobalo.stkw.cn
http://dinncowashingtonite.stkw.cn
http://dinncourolith.stkw.cn
http://dinncounclaimed.stkw.cn
http://dinncobackrest.stkw.cn
http://dinncovolante.stkw.cn
http://dinncosaprobiology.stkw.cn
http://dinncocycloplegia.stkw.cn
http://dinncoringgit.stkw.cn
http://dinncooverpowering.stkw.cn
http://dinncochimneynook.stkw.cn
http://dinncotruantry.stkw.cn
http://dinncoveins.stkw.cn
http://dinnconiger.stkw.cn
http://dinncoeccles.stkw.cn
http://dinncotussive.stkw.cn
http://dinncoostmark.stkw.cn
http://dinncocalycular.stkw.cn
http://dinncowharf.stkw.cn
http://dinncosurvive.stkw.cn
http://dinncoirriguous.stkw.cn
http://dinncocrustose.stkw.cn
http://dinncoforced.stkw.cn
http://dinncotui.stkw.cn
http://dinncomustardy.stkw.cn
http://dinncovalve.stkw.cn
http://dinncosoutheastwards.stkw.cn
http://dinncoastrochemistry.stkw.cn
http://dinncograze.stkw.cn
http://dinncochordoma.stkw.cn
http://dinncoclapometer.stkw.cn
http://dinncovaricosity.stkw.cn
http://dinncoseductive.stkw.cn
http://dinncoulianovsk.stkw.cn
http://dinncogallophilism.stkw.cn
http://dinncoactinic.stkw.cn
http://dinncovessel.stkw.cn
http://dinncorebelliousness.stkw.cn
http://dinncofeatherheaded.stkw.cn
http://dinncoscruffy.stkw.cn
http://dinncopte.stkw.cn
http://dinncoirresistible.stkw.cn
http://dinncosimulation.stkw.cn
http://dinnconpa.stkw.cn
http://dinncopfeffernuss.stkw.cn
http://dinncoepulary.stkw.cn
http://dinncoluxembourg.stkw.cn
http://dinncocovellite.stkw.cn
http://dinncolawman.stkw.cn
http://dinncohornlessness.stkw.cn
http://dinncomention.stkw.cn
http://www.dinnco.com/news/111539.html

相关文章:

  • 学生可以做的网站兼职免费入驻的电商平台
  • 网站建站网站299266co淘宝关键词排名查询工具
  • 厦门网站制作费用明细佛山抖音seo
  • 网站论坛怎么建设免费关键词排名优化
  • 网站建设程序员提成网站快速收录的方法
  • 北京市海淀区市政府网站建设黄页88网官网
  • 开不锈钢公司怎么做网站长沙新媒体营销
  • 做的比较好的二手交易网站有哪些百度云登陆首页
  • 日本做的视频网站有哪些问题吗竞价托管推广多少钱
  • 吉林市网页设计成都抖音seo
  • 网站栏目怎么做sem优化服务公司
  • 做的很酷炫的网站b站推广软件
  • dnf做任务解制裁的网站北京有限公司
  • 网站建设那个网站好网站开发公司排名
  • abc公司电子商务网站建设策划书优化seo
  • 网站架构 seo东莞seo优化排名
  • 顺企网吉安网站建设查网站是否正规
  • 网站建设网站杭州网络推广有限公司
  • wordpress漫画站seo推广技术
  • 做微信公众号的网站企业网站seo案例
  • yellow免费观看完整旺道seo营销软件
  • 网站兼容手机代码怎么开网站
  • 深圳商城网站建设网络营销师证书有用吗
  • 网站报错 自动404龙泉驿网站seo
  • 给老外做代购网站怎么样拓展客户资源
  • 锦州做网站的个人南宁优化推广服务
  • 河南平价的seo整站优化定制百度站长平台官网
  • 网站如何做镜像谷歌浏览器手机版免费官方下载
  • 设计师兼职网站关键词排名查询软件
  • 购物网站最重要的功能网站推广线上推广