Python操作PDF文件之實現A3頁面轉A4
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頁。非常的完美,打印工作可以順利進行瞭。
到此這篇關於Python操作PDF文件之實現A3頁面轉A4的文章就介紹到這瞭,更多相關Python PDF A3頁面轉A4內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Python實現PDF掃描件生成DOCX或EXCEL功能
- 如何使用Python進行PDF圖片識別OCR
- Python提取PDF中的圖片的實現示例
- python將紅底證件照轉成藍底的實現方法
- Python實現PDF轉換文本詳解