Python使操作PDF文件变得有趣

简介: Python使操作PDF文件变得有趣

Python使操作PDF文件变得有趣

大家在平时操作PDF文件时是不是感觉很枯燥

那么今天就教大家利用Python让操作PDF文件变得有趣起来

目录
工具
从PDF中提取文本
旋转和叠加页面
加密PDF文件
创建PDF文件
总结

PDF是Portable Document Format的缩写,这类文件通常使用.pdf作为其扩展名。在日常开发工作中,最容易遇到的就是从PDF中读取文本内容以及用已有的内容生成PDF文档这两个任务。

工具 :

python3.7

Pycharm

PDF

PyPDF2

reportlab

从PDF中提取文本
PyPDF2没有办法从PDF文档中提取图像、图表或其他媒体,但它可以提取文本,并将其返回为Python字符串。

import PyPDF2

reader = PyPDF2.PdfFileReader('test.pdf')
page = reader.getPage(0)
print(page.extractText())

旋转和叠加页面

​ 上面的代码中通过创建PdfFileReader对象的方式来读取PDF文档,该对象的getPage方法可以获得PDF文档的指定页并得到一个PageObject对象,通过PageObject对象的rotateClockwise和rotateCounterClockwise方法可以实现页面的顺时针和逆时针方向旋转,通过PageObject对象的addBlankPage方法可以添加一个新的空白页,代码如下所示。

import PyPDF2

from PyPDF2.pdf import PageObject

创建一个读PDF文件的Reader对象

reader = PyPDF2.PdfFileReader('resources/xxx.pdf')

创建一个写PDF文件的Writer对象

writer = PyPDF2.PdfFileWriter()

对PDF文件所有页进行循环遍历

for page_num in range(reader.numPages):

# 获取指定页码的Page对象
current_page = reader.getPage(page_num)  # type: PageObject
if page_num % 2 == 0:
    # 奇数页顺时针旋转90度
    current_page.rotateClockwise(90)
else:
    # 偶数页反时针旋转90度
    current_page.rotateCounterClockwise(90)
writer.addPage(current_page)

最后添加一个空白页并旋转90度

page = writer.addBlankPage() # type: PageObject
page.rotateClockwise(90)

通过Writer对象的write方法将PDF写入文件

with open('resources/xxx.pdf', 'wb') as file:

writer.write(file)

加密PDF文件

​ 使用PyPDF2中的PdfFileWrite对象可以为PDF文档加密,如果需要给一系列的PDF文档设置统一的访问口令,使用Python程序来处理就会非常的方便。i

mport PyPDF2

reader = PyPDF2.PdfFileReader('resources/XGBoost.pdf')
writer = PyPDF2.PdfFileWriter()
for page_num in range(reader.numPages):

writer.addPage(reader.getPage(page_num))

通过encrypt方法加密PDF文件,方法的参数就是设置的密码

writer.encrypt('foobared')
with open('resources/XGBoost-encrypted.pdf', 'wb') as file:

writer.write(file)

创建PDF文件

​ 创建PDF文档需要三方库reportlab的支持,使用 pip install reportlab 命令安装

from reportlab.lib.pagesizes import A4
from reportlab.pdfbase import pdfmetrics
from reportlab.pdfbase.ttfonts import TTFont
from reportlab.pdfgen import canvas

pdf_canvas = canvas.Canvas('resources/python创建.pdf', pagesize=A4)
width, height = A4

绘图

image = canvas.ImageReader('resources/xxx.jpg')
pdf_canvas.drawImage(image, 20, height - 395, 250, 375)

显示当前页

pdf_canvas.showPage()

注册字体文件

pdfmetrics.registerFont(TTFont('Font1', 'resources/fonts/Vera.ttf'))
pdfmetrics.registerFont(TTFont('Font2', 'resources/fonts/青呱石头体.ttf'))

写字

pdf_canvas.setFont('Font2', 40)
pdf_canvas.setFillColorRGB(0.9, 0.5, 0.3, 1)
pdf_canvas.drawString(width // 2 - 120, height // 2, '你好,世界!')
pdf_canvas.setFont('Font1', 40)
pdf_canvas.setFillColorRGB(0, 1, 0, 0.5)
pdf_canvas.rotate(18)
pdf_canvas.drawString(250, 250, 'hello, world!')

保存

pdf_canvas.save()

目录
相关文章
|
2天前
|
Python
【Python操作基础】——帮助文档
【Python操作基础】——帮助文档
|
2天前
|
Python
【Python操作基础】——字典,迭代器和生成器
【Python操作基础】——字典,迭代器和生成器
|
2天前
|
Python
【Python操作基础】——集合
【Python操作基础】——集合
|
2天前
|
Python
【Python操作基础】——字符串
【Python操作基础】——字符串
|
2天前
|
Python
【Python操作基础】——while语句用法和pass语句
【Python操作基础】——while语句用法和pass语句
|
2天前
|
Python
【Python操作基础】——if语句用法
【Python操作基础】——if语句用法
|
2天前
|
存储 Python
【Python操作基础】系列——赋值语句
【Python操作基础】系列——赋值语句
|
2天前
|
Python
【Python操作基础】——语句书写规范
【Python操作基础】——语句书写规范
|
2天前
|
Python
【Python操作基础】——变量操作
【Python操作基础】——变量操作
|
2天前
|
Python
【Python操作基础】——数据类型
【Python操作基础】——数据类型