网站首页 > 教程文章 正文
今天在街上打印店给儿子打印试卷时,我在想:能不能,把它分割成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,它都能纵向分割,快去试一试吧。
- 上一篇: Python rembg 库去除图片背景
- 下一篇: Python 开发工程师必会的 5 个文件操作库
猜你喜欢
- 2025-05-28 21-Python-文件操作
- 2025-05-28 为你的python程序上锁:软件序列号生成器
- 2025-05-28 用Python做个“冰墩墩雪容融”桌面部件(好玩又有趣)
- 2025-05-28 Dify工具使用全场景:通过文本生成word的指南(功能篇·第4期)
- 2025-05-28 Pytorch入门-Day9:数据加载(Dataset与DataLoader)
- 2025-05-28 2025年必学的Python自动化办公的15个实用脚本
- 2025-05-28 自学Python第二天
- 2025-05-28 ScalersTalk 成长会 Python 小组第 9 周学习笔记
- 2025-05-28 怎么做到的?用python制作九宫格图片,太棒了
- 2025-05-28 利用Dask构建端到端数据处理:从数据摄取到数据库加载的实战指南
- 最近发表
-
- 【Python】一文学会使用 Pandas 库
- Docsify-3分钟搭建属于自己的技术文档WIKI
- Elasticsearch数据迁移方案(elasticsearch索引迁移)
- Vue、Nuxt服务端渲染、NodeJS全栈项目
- Android Studio下载Gradle超时解决方案
- 一文讲清楚 Markdown+Typora+Pandoc+图床+PicGo
- 用户说 | 手把手体验通义灵码 2.0 AI 程序员如何让我进阶“架构师”?
- 15.7k star,经典与效率兼备的后台管理框架
- Cursor + 12306 MCP,打造AI智能选票系统,超酷的!
- 别再自建仓库了,云效Maven仓库不限容量免费用
- 标签列表
-
- location.href (44)
- document.ready (36)
- git checkout -b (34)
- 跃点数 (35)
- 阿里云镜像地址 (33)
- qt qmessagebox (36)
- mybatis plus page (35)
- vue @scroll (38)
- 堆栈区别 (33)
- 什么是容器 (33)
- sha1 md5 (33)
- navicat导出数据 (34)
- 阿里云acp考试 (33)
- 阿里云 nacos (34)
- redhat官网下载镜像 (36)
- srs服务器 (33)
- pico开发者 (33)
- https的端口号 (34)
- vscode更改主题 (35)
- 阿里云资源池 (34)
- os.path.join (33)
- redis aof rdb 区别 (33)
- 302跳转 (33)
- http method (35)
- js array splice (33)