加入收藏 | 设为首页 | 会员中心 | 我要投稿 三明站长网 (https://www.0598zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 教程 > 正文

PHP如何借助Python实现对PDF文件的操作

发布时间:2021-12-05 14:20:06 所属栏目:教程 来源:互联网
导读:需求:在PHP里实现了把8.pdf的前4页pdf文件截取出来生成新的pdf文件。 详细步骤如下: 1. 安装Python第三方库PyPDF2 前提:python必须是3.x版本以上,必要时需要升级pip3,命令如下:pip3 install --upgrade pip PyPDF 自 2010年 12月开始就不在更新了,PyPDF2
需求:在PHP里实现了把8.pdf的前4页pdf文件截取出来生成新的pdf文件。
 
详细步骤如下:
 
1. 安装Python第三方库PyPDF2
 
前提:python必须是3.x版本以上,必要时需要升级pip3,命令如下:pip3 install --upgrade pip
PyPDF 自 2010年 12月开始就不在更新了,PyPDF2 接棒 PyPDF, 在此使用PyPDF2。
 
安装命令:pip install PyPDF2
 
2、编写python脚本:mypdf.py
 
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里执行/usr/local/bin/python3 /bbs_pdf/mypdf.py 8.pdf 4
实现了把8.pdf的前4页pdf文件截取出来。
 
3、在PHP里调用python脚本实现。
 
<?php
$output = shell_exec('/usr/local/bin/python3 /bbs_pdf/mypdf.py 8.pdf 4');
echo 1;
$array = explode(',', $output);
foreach ($array as $value) {
#echo "n";
echo $value;
echo "<br>";
}
?>
 
通过以上步骤就实现了在PHP里借助python第三方库实现截取pdf文件的操作。

(编辑:三明站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!