Python操作PDF文件之实现A3页面转A4

作者:侯小啾 时间:2021-03-06 19:45:06 

1. 需求概述

最近接到一份PDF资料需要打印,奈何页面是如图所示的A3格式的,奈何目前条件只支持打印A4。

我想要把每页的一个大页面裁成两个小的页面,以便打印工作的顺利进行。

Python操作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,打开后效果如下图所示:

Python操作PDF文件之实现A3页面转A4

可以看到页面成功地被分割,并由原来的11页变成了22页。非常的完美,打印工作可以顺利进行了。

来源:https://blog.csdn.net/weixin_48964486/article/details/127609904

标签:Python,PDF,操作
0
投稿

猜你喜欢

  • python中format函数与round函数的区别

    2021-03-31 03:33:29
  • ASP写的汉字转换为UTF-8的一段代码

    2009-07-05 18:49:00
  • Pytorch图像处理注意力机制解析及代码详解

    2023-10-05 03:23:03
  • Vue 解决在element中使用$notify在提示信息中换行问题

    2024-04-28 10:53:35
  • Vue2 响应式系统之深度响应

    2024-04-26 17:40:05
  • 详解在Python的Django框架中创建模板库的方法

    2023-08-15 10:32:56
  • 用Python制作检测Linux运行信息的工具的教程

    2022-03-01 17:49:15
  • 详解python读写json文件

    2022-11-01 16:18:53
  • python 获取sqlite3数据库的表名和表字段名的实例

    2024-01-24 13:34:22
  • javascript发表评论或者留言时的展开效果

    2024-05-02 17:29:19
  • python使用socket进行简单网络连接的方法

    2021-05-16 22:53:03
  • CentOS6.4上使用yum安装mysql

    2024-01-18 10:07:09
  • ASP.NET 2.0中的数据操作之九:跨页面的主/从报表

    2023-07-19 20:28:42
  • Python标准库之time库的使用教程详解

    2023-07-25 05:25:57
  • 详解vue-cli 脚手架 安装

    2024-05-09 10:40:06
  • thinkphp3.x连接mysql数据库的方法(具体操作步骤)

    2023-11-22 20:04:41
  • Python中创建表格详细过程

    2023-10-08 02:42:51
  • layui select获取自定义属性方法

    2024-06-23 14:14:21
  • 常见JS前端接口校验方式总结

    2024-04-17 10:00:00
  • CentOS下重置MySQL的root密码的教程

    2024-01-25 19:20:40
  • asp之家 网络编程 m.aspxhome.com