需求:在PHP里實現(xiàn)了把8.pdf的前4頁pdf文件截取出來生成新的pdf文件。
創(chuàng)新互聯(lián)建站專注于瓊山企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站,購物商城網(wǎng)站建設(shè)。瓊山網(wǎng)站建設(shè)公司,為瓊山等地區(qū)提供建站服務(wù)。全流程按需設(shè)計,專業(yè)設(shè)計,全程項目跟蹤,創(chuàng)新互聯(lián)建站專業(yè)和態(tài)度為您提供的服務(wù)
詳細步驟如下:
前提:python必須是3.x版本以上,必要時需要升級pip3,命令如下:pip3 install --upgrade pip
PyPDF 自 2010年 12月開始就不在更新了,PyPDF2 接棒 PyPDF, 在此使用PyPDF2。
安裝命令:pip install PyPDF2
from PyPDF2 import PdfFileReader, PdfFileWriter
import sys
def split_pdf(infn, outfn):
pdf_output = PdfFileWriter()
pdf_input = PdfFileReader(open(infn, 'rb'))
# 獲取 pdf 共用多少頁
page_count = pdf_input.getNumPages()
print(page_count)
# 將 pdf 第1頁到int(sys.argv[2])頁的頁面,輸出到一個新的文件
for i in range(0, int(sys.argv[2])):
pdf_output.addPage(pdf_input.getPage(i))
pdf_output.write(open(outfn, 'wb'))
def merge_pdf(infnList, outfn):
pdf_output = PdfFileWriter()
for infn in infnList:
pdf_input = PdfFileReader(open(infn, 'rb'))
# 獲取 pdf 共用多少頁
page_count = pdf_input.getNumPages()
print(page_count)
for i in range(page_count):
pdf_output.addPage(pdf_input.getPage(i))
pdf_output.write(open(outfn, 'wb'))
if __name__ == '__main__':
infn = '/bbs_pdf/'+ sys.argv[1]
outfn = '/bbs_pdf/outfn.pdf'
split_pdf(infn, outfn)
以上腳本在linux里執(zhí)行/usr/local/bin/python3 /bbs_pdf/mypdf.py 8.pdf 4
實現(xiàn)了把8.pdf的前4頁pdf文件截取出來。
";
}
?>
通過以上步驟就實現(xiàn)了在PHP里借助python第三方庫實現(xiàn)截取pdf文件的操作。本人親自開發(fā)可用,有問題可留言,抽空予以解答。