欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用python將圖片版PDF轉(zhuǎn)文字版PDF

 更新時間:2019年05月03日 15:59:20   投稿:WDC  
今天為大家介紹一下如何使用利用python將圖片版PDF轉(zhuǎn)文字版PDF,這里我們需要用到python3.6,pypdf2,ghostscript,PythonMagick,百度文字識別服務(wù)和pdfkit

圖片版PDF無法復(fù)制,轉(zhuǎn)化成文字版的PDF后使用更方便.

我們需要用到python3.6,pypdf2,ghostscript,PythonMagick,百度文字識別服務(wù)和pdfkit.

安裝

安裝python3.6 略

安裝ghostscript

https://ghostscript.com/download/gsdnld.html

安裝wkhtmltopdf

https://wkhtmltopdf.org/downloads.html

pip安裝PyPDF2,ghostscript,baidu-aip,pdfkit

pip install PyPDF2
pip install ghostscript
pip install baidu-aip
pip install pdfkit

pip安裝PythonMagick

https://www.lfd.uci.edu/~gohlke/pythonlibs/

cd 下載目錄
pip install PythonMagick‑0.9.13‑cp36‑cp36m‑win_amd64.whl

pypdf2用于拆分和合并PDF

示例代碼如下:

#導(dǎo)入PdfFileReader和PdfFileWriter
from PyPDF2 import PdfFileReader, PdfFileWriter
#獲取一個pdf對象
pdf_input = PdfFileReader(open(r'pdf路徑', 'rb'))
#獲取pdf頁數(shù)
page_count = pdf_input.getNumPages()
#獲取pdf第四頁的內(nèi)容
page = pdf_input.getPage(3)
page['/Contents']
#獲取一個pdfWriter對象
pdf_output = PdfFileWriter()
# 將一個 PageObject 加入到 PdfFileWriter 中
pdf_output.addPage(page)
#把新pdf保存
pdf_output.write(open(r'新pdf路徑','wb'))

PythonMagick用于將單頁PDF轉(zhuǎn)化為jpg

百度云-文字識別-python SDK

每天有500次免費的識別
示例代碼如下:

#導(dǎo)入baidu-aip
from aip import AipOcr
#https://console.bce.baidu.com/#/index/overview
#產(chǎn)品服務(wù)->人工智能->文字識別->創(chuàng)建應(yīng)用
#獲取以下三個值
APP_ID = '??'
API_KEY = '??'
SECRET_KEY = '?? '
#新建一個AipOcr
client = AipOcr(APP_ID, API_KEY, SECRET_KEY)
#讀取本地圖片的函數(shù)
def get_file_content(filePath):
  with open(filePath, 'rb') as fp:
    return fp.read()
#讀取本地圖片
image = get_file_content('p1.jpg')
#可選參數(shù)
options = {}
options["language_type"] = "CHN_ENG"
options["detect_direction"] = "true"
options["detect_language"] = "true"
options["probability"] = "true"
#通用文字識別
client.basicGeneral(image, options)

#讀取網(wǎng)絡(luò)圖片
url = "https://note.youdao.com/yws/public/resource/1577071c1ffa2b6bf4e238ef6dbcfbf5/xmlnote/E5A19BEDFEBA4879B217C5BBF53B0245/22138"
#可選參數(shù)
options = {}
options["language_type"] = "CHN_ENG"
options["detect_direction"] = "true"
options["detect_language"] = "true"
options["probability"] = "true"
#通用文字識別
client.basicGeneralUrl(url, options)

#讀取本地表格圖片的函數(shù)
def get_file_content(filePath):
  with open(filePath, 'rb') as fp:
    return fp.read()
#讀取本地表格圖片
image = get_file_content('p2.jpg')
#可選參數(shù)
options = {}
options["language_type"] = "CHN_ENG"
options["detect_direction"] = "true"
options["detect_language"] = "true"
options["probability"] = "true"
#通用文字識別
client.basicGeneral(image, options)
#讀取表格分割效果較差!

pdfkit用于利用字符串生成pdf
示例代碼如下:

#pdfkit安裝位置設(shè)置
path_wk = r'pdfkit安裝位置設(shè)置'
pdfkit_config = pdfkit.configuration(wkhtmltopdf = path_wk)
#pdfkit參數(shù)
pdfkit_options = {'encoding': 'UTF-8',}
#制作PDF
pdfkit.from_string(('string'),'D:\test.pdf',configuration=pdfkit_config,options=pdfkit_options)

完整代碼如下

#導(dǎo)入所需包

#os,操作文件和路徑
import os
#ghostscript,代碼簡化
import ghostscript
#pypdf2,拆分pdf
from PyPDF2 import PdfFileReader, PdfFileWriter
#PythonMagick,單頁PDF轉(zhuǎn)圖片
from PythonMagick import Image
#baidu-aip,百度文字識別
from aip import AipOcr
#pdfkit,字符串制作PDF
import pdfkit

#參數(shù)

path='??'
pdfname='??'
DPI='85'
#https://console.bce.baidu.com/#/index/overview
#產(chǎn)品服務(wù)->人工智能->文字識別->創(chuàng)建應(yīng)用
#獲取以下三個值
APP_ID = '??'
API_KEY = '??'
SECRET_KEY = '?? '
#pdfkit安裝位置設(shè)置
path_wk = r'pdfkit安裝位置設(shè)置'
pdfkit_config = pdfkit.configuration(wkhtmltopdf = path_wk)
#pdfkit參數(shù)
pdfkit_options = {'encoding': 'UTF-8',}

#PDF轉(zhuǎn)化為圖片

os.chdir(path)
pdf_input = PdfFileReader(open(pdfname, 'rb'))
#自動獲取PDF頁數(shù)
page_count = pdf_input.getNumPages()
page_range=range(page_count)
#也可以手工指定PDF需要轉(zhuǎn)換的頁數(shù)
#page_range=range(0,100)
#使用PyPDF和ghostscript
#==超級好用,超級直觀,超級短==
for page_num in page_range:
  im = Image()
  im.density(DPI)
  im.read(pdfname + '[' + str(page_num) +']')
  im.write(str(page_num)+ '.jpg')

#圖片轉(zhuǎn)化為字符串

#新建一個AipOcr
client = AipOcr(APP_ID, API_KEY, SECRET_KEY)
#讀取本地圖片的函數(shù)
def get_file_content(filePath):
  with open(filePath, 'rb') as fp:
    return fp.read()
#可選參數(shù)
options = {}
options["language_type"] = "CHN_ENG"
options["detect_direction"] = "false"
options["detect_language"] = "false"
options["probability"] = "false"
allteststr=[]
for page_num in page_range:
  #讀取本地圖片
  image = get_file_content(r'%s\%s.jpg' % (path,page_num))
  #通用文字識別,得到的是一個dict
  testjson=client.basicGeneral(image, options)
  teststr=''
  for x in testjson['words_result']:
    teststr=teststr+x['words']+'</br>'
  allteststr.append(teststr)

#字符串寫入PDF
for page_num in page_range:
  pdfkit.from_string((allteststr[page_num]),'%s.pdf' % (str(page_num)),configuration=pdfkit_config,options=pdfkit_options)
#合并單頁PDF
pdf_output = PdfFileWriter()
for page_num in page_range:
  os.chdir(path)
  pdf_input = PdfFileReader(open('%s.pdf' % (str(page_num)), 'rb'))
  page = pdf_input.getPage(0)
  pdf_output.addPage(page)
pdf_output.write(open('newpdf.pdf','wb'))

以上就是為大家介紹的如何使用python3.6,pypdf2,ghostscript,PythonMagick,百度文字識別服務(wù)和pdfkit

相關(guān)文章

  • Anaconda修改默認虛擬環(huán)境安裝位置的方案分享

    Anaconda修改默認虛擬環(huán)境安裝位置的方案分享

    新安裝Anaconda后,在創(chuàng)建環(huán)境時環(huán)境自動安裝在C盤,但是C盤空間有限,下面這篇文章主要給大家介紹了關(guān)于Anaconda修改默認虛擬環(huán)境安裝位置的相關(guān)資料,需要的朋友可以參考下
    2023-01-01
  • python遞歸刪除指定目錄及其所有內(nèi)容的方法

    python遞歸刪除指定目錄及其所有內(nèi)容的方法

    下面小編就為大家?guī)硪黄猵ython遞歸刪除指定目錄及其所有內(nèi)容的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • numpy matrix和array的乘和加實例

    numpy matrix和array的乘和加實例

    今天小編就為大家分享一篇numpy matrix和array的乘和加實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-06-06
  • Python中循環(huán)依賴問題及其解決方案

    Python中循環(huán)依賴問題及其解決方案

    在軟件開發(fā)中,循環(huán)依賴是一個常見的問題,尤其是在使用 Python 這樣的動態(tài)語言時,循環(huán)依賴指的是兩個或多個模塊或組件相互依賴,形成一個閉環(huán),本文將探討 Python 中循環(huán)依賴的問題,并提供一些解決方案,需要的朋友可以參考下
    2024-06-06
  • python實現(xiàn)對求解最長回文子串的動態(tài)規(guī)劃算法

    python實現(xiàn)對求解最長回文子串的動態(tài)規(guī)劃算法

    這篇文章主要為大家詳細介紹了python實現(xiàn)對求解最長回文子串的動態(tài)規(guī)劃算法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • Python 進程操作之進程間通過隊列共享數(shù)據(jù),隊列Queue簡單示例

    Python 進程操作之進程間通過隊列共享數(shù)據(jù),隊列Queue簡單示例

    這篇文章主要介紹了Python 進程操作之進程間通過隊列共享數(shù)據(jù),隊列Queue,結(jié)合實例形式分析了Python進程數(shù)據(jù)共享、隊列數(shù)據(jù)處理相關(guān)操作技巧,需要的朋友可以參考下
    2019-10-10
  • python繪制玫瑰的實現(xiàn)代碼

    python繪制玫瑰的實現(xiàn)代碼

    這篇文章主要介紹了python繪制玫瑰的實現(xiàn)代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • Windows下python2.7.8安裝圖文教程

    Windows下python2.7.8安裝圖文教程

    這篇文章主要為大家詳細介紹了Windows下python2.7.8安裝圖文教程,在安裝過程中出現(xiàn)“python不是內(nèi)部或外部命令”提示的解決方法,感興趣的小伙伴們可以參考一下
    2016-05-05
  • 輕松理解Python 中的 descriptor

    輕松理解Python 中的 descriptor

    本文給大家分Python 中的 descriptor相關(guān)知識,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-09-09
  • Python 中的range(),以及列表切片方法

    Python 中的range(),以及列表切片方法

    今天小編就為大家分享一篇Python 中的range(),以及列表切片方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07

最新評論