Python操作PDF文件之實(shí)現(xiàn)A3頁(yè)面轉(zhuǎn)A4
1. 需求概述
最近接到一份PDF資料需要打印,奈何頁(yè)面是如圖所示的A3格式的,奈何目前條件只支持打印A4。
我想要把每頁(yè)的一個(gè)大頁(yè)面裁成兩個(gè)小的頁(yè)面,以便打印工作的順利進(jìn)行。

遂決定寫(xiě)一段python代碼,來(lái)實(shí)現(xiàn)該功能。
2. 代碼實(shí)現(xiàn)
首先在當(dāng)前目錄下創(chuàng)建一個(gè)python文件,并編輯以下代碼。
導(dǎo)入相關(guān)庫(kù)后,代碼共定義三個(gè)函數(shù),
第一個(gè)函數(shù)將pdf拆分為多個(gè)圖片,放在自動(dòng)新建的images1文件夾中。
第二個(gè)函數(shù)則將每個(gè)圖片進(jìn)行切割,切割后的圖片放在自動(dòng)創(chuàng)建的images2文件夾中。
第三個(gè)函數(shù)則將images2文件夾中的每個(gè)圖片合并成為pdf。
import fitz
import time
import os
import cv2
from fpdf import FPDF
from PIL import Image
# 將pdf分割為圖片,并建立一個(gè)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開(kāi)始轉(zhuǎn)換..." % 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) + ' 頁(yè)生成圖片累計(jì)用時(shí):' + str(timep_end - timep_start))
time_end = time.time()
print('拆解累計(jì)用時(shí):' + str(time_end - time_start))
# 將images1文件夾中的每個(gè)圖片,左右分割為兩張,并新建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文件夾中的圖片合并成為一個(gè)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")
# 執(zhí)行
if __name__ == "__main__":
to_image("test.pdf")
cut_img()
makePdf("result.pdf")
處理后得到的文件,即result.pdf,打開(kāi)后效果如下圖所示:

可以看到頁(yè)面成功地被分割,并由原來(lái)的11頁(yè)變成了22頁(yè)。非常的完美,打印工作可以順利進(jìn)行了。
到此這篇關(guān)于Python操作PDF文件之實(shí)現(xiàn)A3頁(yè)面轉(zhuǎn)A4的文章就介紹到這了,更多相關(guān)Python PDF A3頁(yè)面轉(zhuǎn)A4內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python實(shí)現(xiàn)Linux中的du命令
這篇文章主要介紹了Python實(shí)現(xiàn)Linux中簡(jiǎn)單du命令,需要的朋友可以參考下2017-06-06
python Pandas庫(kù)基礎(chǔ)分析之時(shí)間序列的處理詳解
這篇文章主要介紹了python Pandas庫(kù)基礎(chǔ)分析之時(shí)間序列的處理詳解,Pandas作為Python環(huán)境下的數(shù)據(jù)分析庫(kù),更是提供了強(qiáng)大的日期數(shù)據(jù)處理的功能,是處理時(shí)間序列的利器,需要的朋友可以參考下2019-07-07
python dataframe 輸出結(jié)果整行顯示的方法
今天小編就為大家分享一篇python dataframe 輸出結(jié)果整行顯示的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-06-06
解決python 3 urllib 沒(méi)有 urlencode 屬性的問(wèn)題
今天小編就為大家分享一篇解決python 3 urllib 沒(méi)有 urlencode 屬性的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-08-08
python des,aes,rsa加解密的實(shí)現(xiàn)
這篇文章主要介紹了python des,aes,rsa加解密的實(shí)現(xiàn),幫助大家更好的理解和使用python,感興趣的朋友可以了解下2021-01-01
python 解決pycharm運(yùn)行py文件只有unittest選項(xiàng)的問(wèn)題
這篇文章主要介紹了python 解決pycharm運(yùn)行py文件只有unittest選項(xiàng)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09

