百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

PyPDF2是python的处理PDF文件的基本操作介绍

off999 2024-09-21 20:58 28 浏览 0 评论

1 说明

1.1 PyPDF2:使用它可以轻松的处理 pdf 文件,它提供了读,割,合并,文件转换等多种操作。

1.2 PyPDF2可以对PDF文件进行加密,解密,目前已经更新到PyPDF3版本,本文基于PyPDF2进行介绍。

1.3 环境:python3.8,deepin-linux操作系统,微软vscode编辑器。


2 安装

pip install PyPDF2

#pip3.8 install PyPDF2  #本机安装

3 相关网址:

https://pythonhosted.org/PyPDF2/

https://pypi.org/project/PyPDF2/1.26.0/

https://github.com/mstamy2/PyPDF2/

4 PDF文件的合并,mergepdf.py代码如下:

#pdf文件合并=merge
from PyPDF2 import PdfFileMerger

merger = PdfFileMerger()
#将3个pdf文件合并,注意路径和目录
input1 = open("/home/xgj/Desktop/PyPDF2/1.pdf", "rb")
input2 = open("/home/xgj/Desktop/PyPDF2/2.pdf", "rb")
input3 = open("/home/xgj/Desktop/PyPDF2/3.pdf", "rb")

#默认作为第一张,即position = 1,pages = (0,1)代表1.pdf的第一张,如果有很多张,注意取第几张到第几张
merger.append(fileobj = input1, pages = (0,1))

#与上面相同
merger.merge(position = 2, fileobj = input2, pages = (0,1))

# append entire input3 document to the end of the output document
# 将3.pdf添加到上述的后面
merger.append(input3)

# Write to an output PDF document,生成新的pdf
output = open("/home/xgj/Desktop/PyPDF2/document-output.pdf", "wb")
merger.write(output)

5 拆分pdf文件,splitpdf.py代码

from PyPDF2 import PdfFileReader, PdfFileWriter
 
def split(path, name_of_split):
    pdf = PdfFileReader(path)
    for page in range(pdf.getNumPages()):
        pdf_writer = PdfFileWriter()
        pdf_writer.addPage(pdf.getPage(page))
        #拆分在根目录下
        #output = f'{name_of_split}{page}.pdf'
        #指定目录下
        output = f'/home/xgj/Desktop/PyPDF2/{name_of_split}{page}.pdf'
        with open(output, 'wb') as output_pdf:
            pdf_writer.write(output_pdf)
 
if __name__ == '__main__':
    #要拆分的pdf文件及目录
    path = '/home/xgj/Desktop/PyPDF2/4.pdf'
    #注意name_of_split=NO
    split(path, 'NO')

6 pdf文件加密,jiamipdf.py代码

from PyPDF2 import PdfFileWriter, PdfFileReader
 
def add_encryption(input_pdf, output_pdf, password):
    pdf_writer = PdfFileWriter()
    pdf_reader = PdfFileReader(input_pdf)
    for page in range(pdf_reader.getNumPages()):
        pdf_writer.addPage(pdf_reader.getPage(page))
    pdf_writer.encrypt(user_pwd=password, owner_pwd=None,use_128bit=True)
    with open(output_pdf, 'wb') as fh:
        pdf_writer.write(fh)

if __name__ == '__main__':
    #input是需要加密的pdf文件和目录,output是生成加密的原pdf的新pdf文件
    #自定义密码
    add_encryption(input_pdf='/home/xgj/Desktop/PyPDF2/1.pdf',
                   output_pdf='/home/xgj/Desktop/PyPDF2/1m.pdf',password='123456')

7 解密pdf文件

7.1 jiemipdf.py代码

import os
#指定目录,即更改根目录的方法
os.chdir('/home/xgj/Desktop/PyPDF2')
from PyPDF2 import PdfFileReader,PdfFileWriter

pdf_reader = PdfFileReader("1m.pdf")
#知道密码情况下,注意是解密,不是破解密码
pdf_reader.decrypt("123456")
pdf_writer = PdfFileWriter()
for page in range(pdf_reader.getNumPages()):
    pdf_writer.addPage(pdf_reader.getPage(page))

with open("encrypted.pdf", "wb") as out:
    pdf_writer.write(out)

7.2 注意细节:适合批量解密pdf文件,并且自己知道密码。

7.3 注意代码简洁,导入os,提前设路径,顺带复习python的os模块的路径设置。

===========================

8 pdf加水印:watermarkpdf.py代码

from PyPDF2 import PdfFileReader, PdfFileWriter
#安装:pip install reportlab,下次单独将这个模块
from reportlab.lib.units import cm
from reportlab.pdfgen import canvas
import reportlab.pdfbase.ttfonts

# 创建水印信息
def create_watermark(content):
    #生成一个单独的水印pdf,注意路径和目录
    file_name = "/home/xgj/Desktop/PyPDF2/mark.pdf"
    c = canvas.Canvas(file_name, pagesize=(30 * cm, 30 * cm))
    # 移动坐标原点(坐标系左下为(0,0))
    c.translate(4 * cm, 0 * cm)
    # 设置字体格式与大小,中文需要加载能够显示中文的字体,否则就会乱码,注意字体路径
    # 如果是中文就是try
    try:
        reportlab.pdfbase.pdfmetrics.registerFont(reportlab.pdfbase.ttfonts.TTFont('yahei', 'hwfs.ttf'))
        c.setFont('yahei', 50)
    #如果是英文就是except
    except:
            # 默认字体,只能够显示英文
        c.setFont("Helvetica", 30)
        #这一行多次一举,注释掉
        #content = "I love python"

    # 旋转角度度,坐标系被旋转
    c.rotate(30)
    # 指定填充颜色
    c.setFillColorRGB(0, 0, 0)
    # 设置透明度,1为不透明
    c.setFillAlpha(0.05)
    # 画几个文本,注意坐标系旋转的影响
    c.drawString(0 * cm, 3 * cm, content)
    # 关闭并保存pdf文件
    c.save()
    return file_name
 
# 插入水印
def add_watermark(pdf_file_in, pdf_file_mark, pdf_file_out):
    pdf_output = PdfFileWriter()
    input_stream = open(pdf_file_in, 'rb')
    pdf_input = PdfFileReader(input_stream, strict=False)
    # 获取PDF文件的页数
    pageNum = pdf_input.getNumPages()
    # 读入水印pdf文件
    pdf_watermark = PdfFileReader(open(pdf_file_mark, 'rb'), strict=False)
    # 给每一页打水印
    for i in range(pageNum):
        page = pdf_input.getPage(i)
        page.mergePage(pdf_watermark.getPage(0))
        page.compressContentStreams()  # 压缩内容
        pdf_output.addPage(page)
    pdf_output.write(open(pdf_file_out, 'wb'))
 
if __name__ == '__main__':
    #需要加水印的pdf文件和目录
    pdf_file_in = '/home/xgj/Desktop/PyPDF2/123.pdf'
    #生成新的加过水印的pdf文件
    pdf_file_out = '/home/xgj/Desktop/PyPDF2/watermark.pdf'
    #设置加水印的文字内容:英文
    pdf_file_mark = create_watermark(r'I love python')
    #设置加水印的文字内容:中文
    #pdf_file_mark = create_watermark(r'水印')
    add_watermark(pdf_file_in, pdf_file_mark, pdf_file_out)

自己整理,分享出来,已经亲测,欢迎转发和收藏,自己以后拿来就用,希望大家希望。


相关推荐

Alist 玩家请进:一键部署全新分支 Openlist,看看香不香!

Openlist(其前身是鼎鼎大名的Alist)是一款功能强大的开源文件列表程序。它能像“万能钥匙”一样,解锁并聚合你散落在各处的云盘资源——无论是阿里云盘、百度网盘、GoogleDrive还是...

白嫖SSL证书还自动续签?这个开源工具让我告别手动部署

你还在手动部署SSL证书?你是不是也遇到过这些问题:每3个月续一次Let'sEncrypt证书,忘了就翻车;手动配置Nginx,重启服务,搞一次SSL得花一下午;付费证书太贵,...

Docker Compose:让多容器应用一键起飞

CDockerCompose:让多容器应用一键起飞"曾经我也是一个手动启动容器的少年,直到我的膝盖中了一箭。"——某位忘记--link参数的运维工程师引言:容器化的烦恼与...

申请免费的SSL证书,到期一键续签

大家好,我是小悟。最近帮朋友配置网站HTTPS时发现,还有人对宝塔面板的SSL证书功能还不太熟悉。其实宝塔早就内置了免费的Let'sEncrypt证书申请和一键续签功能,操作简单到连新手都能...

飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx

前面分享了两期TVGate:Q大的转发代理工具TVGate升级了,操作更便捷,增加了新的功能跨平台内网转发神器TVGate部署与使用初体验现在项目已经开源,并支持Docker部署,本文介绍如何通...

Docker Compose 编排实战:一键部署多容器应用!

当项目变得越来越复杂,一个服务已经无法满足需求时,你可能需要同时部署数据库、后端服务、前端网页、缓存组件……这时,如果还一个一个手动dockerrun,简直是灾难这就是DockerCompo...

深度测评:Vue、React 一键部署的神器 PinMe

不知道大家有没有这种崩溃瞬间:领导突然要看项目Demo,客户临时要体验新功能,自己写的小案例想发朋友圈;找运维?排期?还要走工单;自己买服务器?域名、SSL、Nginx、防火墙;本地起服务?断电、关...

超简单!一键启动多容器,解锁 Docker Compose 极速编排秘籍

想要用最简单的方式在本地复刻一套完整的微服务环境?只需一个docker-compose.yml文件,你就能一键拉起N个容器,自动组网、挂载存储、环境隔离,全程无痛!下面这份终极指南,教你如何用...

日志文件转运工具Filebeat笔记_日志转发工具

一、概述与简介Filebeat是一个日志文件转运工具,在服务器上以轻量级代理的形式安装客户端后,Filebeat会监控日志目录或者指定的日志文件,追踪读取这些文件(追踪文件的变化,不停的读),并将来自...

K8s 日志高效查看神器,提升运维效率10倍!

通常情况下,在部署了K8S服务之后,为了更好地监控服务的运行情况,都会接入对应的日志系统来进行检测和分析,比如常见的Filebeat+ElasticSearch+Kibana这一套组合...

如何给网站添加 https_如何给网站添加证书

一、简介相信大家都知道https是更加安全的,特别是一些网站,有https的网站更能够让用户信任访问接下来以我的个人网站五岁小孩为例子,带大家一起从0到1配置网站https本次配置的...

10个Linux文件内容查看命令的实用示例

Linux文件内容查看命令30个实用示例详细介绍了10个Linux文件内容查看命令的30个实用示例,涵盖了从基本文本查看、分页浏览到二进制文件分析的各个方面。掌握这些命令帮助您:高效查看各种文本文件内...

第13章 工程化实践_第13章 工程化实践课

13.1ESLint+Prettier代码规范统一代码风格配置//.eslintrc.jsmodule.exports={root:true,env:{node...

龙建股份:工程项目中标_龙建股份有限公司招聘网

404NotFoundnginx/1.6.1【公告简述】2016年9月8日公告,公司于2016年9月6日收到苏丹共和国(简称“北苏丹”)喀土穆州基础设施与运输部公路、桥梁和排水公司出具的中标通知书...

福田汽车:获得政府补助_福田 补贴

404NotFoundnginx/1.6.1【公告简述】2016年9月1日公告,自2016年8月17日至今,公司共收到产业发展补助、支持资金等与收益相关的政府补助4笔,共计5429.08万元(不含...

取消回复欢迎 发表评论: