欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python操作PDF文件之實(shí)現(xiàn)A3頁面轉(zhuǎn)A4

 更新時(shí)間:2022年11月01日 11:48:18   作者:侯小啾  
這篇文章主要為大家詳細(xì)介紹了Python操作PDF文件之實(shí)現(xiàn)A3頁面轉(zhuǎn)A4功能的相關(guān)資料,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下

1. 需求概述

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

我想要把每頁的一個(gè)大頁面裁成兩個(gè)小的頁面,以便打印工作的順利進(jìn)行。

遂決定寫一段python代碼,來實(shí)現(xiàn)該功能。

2. 代碼實(shí)現(xiàn)

首先在當(dāng)前目錄下創(chuàng)建一個(gè)python文件,并編輯以下代碼。

導(dǎo)入相關(guān)庫后,代碼共定義三個(gè)函數(shù),

第一個(gè)函數(shù)將pdf拆分為多個(gè)圖片,放在自動新建的images1文件夾中。

第二個(gè)函數(shù)則將每個(gè)圖片進(jìn)行切割,切割后的圖片放在自動創(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開始轉(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) + ' 頁生成圖片累計(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,打開后效果如下圖所示:

可以看到頁面成功地被分割,并由原來的11頁變成了22頁。非常的完美,打印工作可以順利進(jìn)行了。

到此這篇關(guān)于Python操作PDF文件之實(shí)現(xiàn)A3頁面轉(zhuǎn)A4的文章就介紹到這了,更多相關(guān)Python PDF A3頁面轉(zhuǎn)A4內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論