今天在街上打印店给儿子打印试卷时,我在想:能不能,把它分割成A4在家中打印,这样就不需要跑到街上的打印店打印卷子了。
原来,老师发的作业,是电子稿,pdf文件,A3格式的试卷。可是家中的打印机只能打印A4,如果打印成A3,字就变小了,于是只有去街上的打印店,有些无奈啊,要知道今天满天黄沙。
不想去街上的打印店,就只能将A3分割成A4,怎么实现呢?我想起了deepseek强大的编程功能,于是我借助以前的经验,在deepseek中,输入以下提示词:
用python编程,根据pdf文件进行分割,分割的要求是:按dpf文件每页的长度进行纵向分割成两个一样大小的页面。
于是deepseek生成以下代码:
import os
from PyPDF2 import PdfReader, PdfWriter
def split_pdf_vertically(input_path, output_path):
"""
将PDF文件的每一页纵向分割成两个相同大小的页面
参数:
input_path: 输入PDF文件路径
output_path: 输出PDF文件路径
"""
# 确保输出目录存在
os.makedirs(os.path.dirname(output_path), exist_ok=True)
# 读取原始PDF
reader = PdfReader(input_path)
writer = PdfWriter()
for page in reader.pages:
# 获取页面尺寸
media_box = page.mediabox
width = media_box.width
height = media_box.height
# 创建左半部分页面
left_page = page
left_page.mediabox.upper_right = (width / 2, height)
left_page.mediabox.lower_left = (0, 0)
# 创建右半部分页面
right_page = page
right_page.mediabox.upper_right = (width, height)
right_page.mediabox.lower_left = (width / 2, 0)
# 添加分割后的页面到输出
writer.add_page(left_page)
writer.add_page(right_page)
# 保存输出PDF
with open(output_path, 'wb') as out_pdf:
writer.write(out_pdf)
if __name__ == "__main__":
input_pdf = "input.pdf" # 替换为你的输入PDF路径
output_pdf = "output.pdf" # 替换为你想要的输出PDF路径
split_pdf_vertically(input_pdf, output_pdf)
print(f"PDF分割完成,结果已保存到 {output_pdf}")
将程序粘贴到python编辑器,按F5运行,你猜结果如何?能生成pdf,但原A3每页的左半部分没有,右半部分各重复了两次,不满足我的需求,于是我又告诉deepseek:
能生成,但没有原每页左半部分,原每页的右半部分各重复了一次
deepseek于是又重新为我生成了新的程序:
import os
from PyPDF2 import PdfReader, PdfWriter
import copy
def split_pdf_vertically(input_path, output_path):
"""
将PDF文件的每一页纵向分割成两个相同大小的页面
参数:
input_path: 输入PDF文件路径
output_path: 输出PDF文件路径
"""
# 确保输出目录存在
os.makedirs(os.path.dirname(output_path), exist_ok=True)
# 读取原始PDF
reader = PdfReader(input_path)
writer = PdfWriter()
for page in reader.pages:
# 获取页面尺寸
media_box = page.mediabox
width = media_box.width
height = media_box.height
# 创建左半部分页面(深拷贝原始页面)
left_page = copy.deepcopy(page)
left_page.mediabox.upper_right = (width / 2, height)
left_page.mediabox.lower_left = (0, 0)
# 创建右半部分页面(深拷贝原始页面)
right_page = copy.deepcopy(page)
right_page.mediabox.upper_right = (width, height)
right_page.mediabox.lower_left = (width / 2, 0)
# 添加分割后的页面到输出
writer.add_page(left_page)
writer.add_page(right_page)
# 保存输出PDF
with open(output_path, 'wb') as out_pdf:
writer.write(out_pdf)
if __name__ == "__main__":
input_pdf = "input.pdf" # 替换为你的输入PDF路径
output_pdf = "output.pdf" # 替换为你想要的输出PDF路径
split_pdf_vertically(input_pdf, output_pdf)
print(f"PDF分割完成,结果已保存到 {output_pdf}")
这一次:程序作了新的变化,主要体现在
关键修改点:
添加了 import copy 用于创建页面对象的深拷贝
使用 copy.deepcopy(page) 为左右两部分创建独立的页面副本
分别修改这两个独立副本的页面边界
我又将其粘贴到python编辑器,按F5运行,结果大功告成!!它能成功的将横向的A3分割成纵向的A3,我太兴奋了,没有编写一句代码,就完成了这个任务。
以下是转化前的pdf文件:A3横向
以下是转化后的pdfA4纵向,双列显示效果。
怎么样?效果真的不错,无论有多少页A3,都可以快速分割成A4,其实,不只是分割A3,只要是横向的pdf,它都能纵向分割,快去试一试吧。