Python操作PDF文件之实现A3页面转A4
作者:侯小啾 时间:2021-03-06 19:45:06
1. 需求概述
最近接到一份PDF资料需要打印,奈何页面是如图所示的A3格式的,奈何目前条件只支持打印A4。
我想要把每页的一个大页面裁成两个小的页面,以便打印工作的顺利进行。
遂决定写一段python代码,来实现该功能。
2. 代码实现
首先在当前目录下创建一个python文件,并编辑以下代码。
导入相关库后,代码共定义三个函数,
第一个函数将pdf拆分为多个图片,放在自动新建的images1文件夹中。
第二个函数则将每个图片进行切割,切割后的图片放在自动创建的images2文件夹中。
第三个函数则将images2文件夹中的每个图片合并成为pdf。
import fitz
import time
import os
import cv2
from fpdf import FPDF
from PIL import Image
# 将pdf分割为图片,并建立一个images1文件夹保存之 传入要拆解的pdf文件名
def to_image(file_name):
dir1 = "images1"
if not os.path.exists(dir1):
os.mkdir(dir1)
time_start = time.time()
doc = fitz.open(file_name)
rotate = int(0)
zoom_x = 2.0
zoom_y = 2.0
trans = fitz.Matrix(zoom_x, zoom_y)
print("%s开始转换..." % file_name)
pg = 0
for page in doc:
timep_start = time.time()
pg += 1
pm = page.get_pixmap(matrix=trans, alpha=False)
new_full_name = dir1 + "/" + file_name.split(".")[0]
filename1 = "{0:s}{1:0>3d}.jpg".format(new_full_name, pg)
pm.save(filename1)
timep_end = time.time()
print('第 ' + str(pg) + ' 页生成图片累计用时:' + str(timep_end - timep_start))
time_end = time.time()
print('拆解累计用时:' + str(time_end - time_start))
# 将images1文件夹中的每个图片,左右分割为两张,并新建images2文件夹以保存文件
def cut_img():
for img in os.listdir("images1"):
image = cv2.imread("images1/" + img)
x0 = int(image.shape[1]/2)
dir2 = "images2"
if not os.path.exists(dir2):
os.mkdir(dir2)
img1 = image[:, 0:x0]
img2 = image[:, x0:]
cv2.imwrite(dir2 + "/" + img[:-4] + '1.jpg', img1)
cv2.imwrite(dir2 + "/" + img[:-4] + '2.jpg', img2)
# 将images2文件夹中的图片合并成为一个pdf,按照文件名的顺序 传入输出的pdf文件名
def makePdf(pdfFileName):
listPages = ["images2/" + imgFileName for imgFileName in os.listdir('images2')]
cover = Image.open(listPages[0])
width, height = cover.size
pdf = FPDF(unit="pt", format = [width, height])
for page in listPages:
pdf.add_page()
pdf.image(page, 0, 0)
pdf.output(pdfFileName, "F")
# 执行
if __name__ == "__main__":
to_image("test.pdf")
cut_img()
makePdf("result.pdf")
处理后得到的文件,即result.pdf
,打开后效果如下图所示:
可以看到页面成功地被分割,并由原来的11页变成了22页。非常的完美,打印工作可以顺利进行了。
来源:https://blog.csdn.net/weixin_48964486/article/details/127609904
标签:Python,PDF,操作
0
投稿
猜你喜欢
关于浮动的前世今生
2009-08-19 18:51:00
asp当中判断函数一览
2010-05-27 12:15:00
ASP转化ip地址为长整型数字
2008-04-06 14:23:00
从 msxml6.dll 中获取 DOMDocument 对象的方法与属性
2009-02-22 18:46:00
pytorch实现focal loss的两种方式小结
2023-07-02 14:43:22
Python中标准库OS的常用方法总结大全
2021-04-29 06:43:41
Python Prim算法通过遍历墙实现迷宫的生成
2022-06-26 08:41:09
关于document.cookie的使用
2008-03-25 12:07:00
Python中的字符串切片(截取字符串)的详解
2023-07-23 20:37:59
ASP中查询数据库记录写入XML文件示例
2007-08-23 13:12:00
Python中的Numpy入门教程
2023-04-10 06:59:10
在SQL查询中使用LIKE来代替IN查询的方法
2011-09-30 11:10:18
如何测试字符串的长度?
2009-11-11 20:02:00
js 返回 utf-8 字符编码是多少个字节, 函数 fUtf8BoundCheck
2010-07-31 18:59:00
列举Python中吸引人的一些特性
2023-12-17 03:25:57
PHP求最大子序列和的算法实现
2023-11-15 04:17:28
亚马逊购物用户体验分析 (二)
2009-10-25 12:48:00
整理一个asp多级树型分类问题的解决方法
2007-10-17 18:38:00
php输出文字乱码的解决方法
2023-11-11 07:40:08
关于jsp版ueditor1.2.5的部分问题解决(上传图片失败)
2023-06-15 06:45:00