Python脚本:用py处理PDF的五大功能

一、代码

【第三方库】3个

【Py版本】3.9

【使用前提】关闭所有的word文档

import os
from datetime import datetime
from docx2pdf import convert
from pdf2docx import parse
from PyPDF2 import PdfMerger
from PyPDF2 import PdfReader,PdfWriter#将文件夹中的所有Word文档批量转换为PDF
def wordtopdf(url):if not os.path.exists(url):return Falseresult=convert(url)#若满足条件"result==None"则表明转换成功return result==None#将文件夹中的所有PDF批量转换为Word文档
def pdftoword(url):if not os.path.exists(url):return Falseall_files_successful = True  # 假设所有文件都成功转换for root, dirs, files in os.walk(url):for file in files:if file.endswith(".pdf"):pdf_file_path = os.path.join(root, file)result = parse(pdf_file_path)if result is not None:  # 转换失败all_files_successful = Falsebreak  # 如果有一个文件转换失败,就跳出内层循环return all_files_successful#合并指定路径的pdf文档(顺序:01 02 03开头文件名依次排序)
def mergepdf(url):if not os.path.exists(url):return Falsemerger = PdfMerger()output_path=url+f"\\合并pdf_{datetime.now().strftime('%Y%m%d%H%M%S')}.pdf"#输出路径# 遍历文件夹下的所有PDF文件并合并for root, dirs, files in os.walk(url):for file in files:if file.endswith(".pdf"):pdf_file_path = os.path.join(root, file)merger.append(pdf_file_path)# 将合并后的PDF保存到指定输出路径merger.write(output_path)merger.close()return True#提取pdf的图像
def pdfimages(pdfurl):if not os.path.exists(pdfurl):return Falsereader = PdfReader(pdfurl)all = len(reader.pages) #返回pdf有多少页count = 0for i in range(0,all):page = reader.pages[i]for image_file_object in page.images:with open(f"{os.path.dirname(pdfurl)}/图{count+1}_{datetime.now().strftime('%Y%m%d%H%M%S')}.png", "wb") as fp:fp.write(image_file_object.data)count += 1return True# 在PDF文件中加水印函数
def pdfcreatewater(pdfurl, pdf_watermark):if not os.path.exists(pdfurl) or not os.path.exists(pdf_watermark):return False# 把水印的文件读入watermark = PdfReader(pdf_watermark)# 取出水印文件的第1页waterpage = watermark.pages[0]# 读入要加入水印的PDF文件vreader = PdfReader(pdfurl)# 取得要加入水印的文件的页数n = len(vreader.pages)# print(n)# 生成一个PDF文件写对象vwriter = PdfWriter()# 通过循环给第一页加上水印for i in range(n):# 取得PDF文件的一页onepage = vreader.pages[i]# 通过mergePage将水印加到该页面onepage.merge_page(waterpage)# 在写对象中加入一页vwriter.add_page(onepage)# 打开最终形成的包含水印的文件with open(f"{os.path.dirname(pdfurl)}/合成水印_{datetime.now().strftime('%Y%m%d%H%M%S')}.pdf", 'wb') as f:# 通过写对象写到文件中vwriter.write(f)return True

二、附录:如何为PDF添加水印

第一步,打开word,按以下步骤添加水印

 二、若水印不够多,则双击页眉,可以拖拽水印

【注意】水印背景是透明的不准出现白色,若有覆盖情况请检查水印文件

【效果】 

 三、附录:如何设置合并顺序

按顺序命名即可,例如"01xxx","02xxx","03xxxx"…………

四、打包为GUI程序(Pyinstaller PyQt5)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/761165.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

GANs生成实例

利用生成对抗网络(GANs)进行图像生成的一个著名实例是深度卷积生成对抗网络(DCGAN)。DCGAN是一种简化版的GANs,它被广泛用于生成逼真的图像。以下是一个简化的DCGAN模型结构: 生成器(Generator…

【目标检测-复制粘贴数据增强】

复制粘贴数据增强 在目标检测、分类和分割任务中,复制粘贴数据增强(Copy-Paste Data Augmentation)是一种创新的数据增广技术,它通过将训练集中的一部分物体实例复制并粘贴到其他图像的合理位置上,以生成新的训练样本…

Linux:网络的初步认知

文章目录 网络的认知如何理解协议网络分层OSI模型TCP/IP五层(或四层)模型网络传输的基本流程协议的参与局域网通信原理 本篇将会引入到网络的话题 网络的认知 第一个问题是,网卡是文件吗?答案是显然的,在Linux下一切皆文件,基于…

29-1 webshell 管理上

一、什么是webshell? WebShell是一种以asp、aspx、php、jsp或者cgi等网页文件形式存在的命令执行环境,也可称为一种网页后门。在发现Web站点漏洞后,攻击者通常会利用这些漏洞上传WebShell程序,从而实现对目标站点的控制。"Web"指的是万维网,而"Shell"…

Trait与生命周期

原文链接:(*∇`*) 咦,又好了~ Rust – xiaocr_bloghttp://www.xiaocr.fun/index.php/2024/03/18/trait%E4%B8%8E%E7%94%9F%E5%91%BD%E5%91%A8%E6%9C%9F/ 目录 Trait 定义trait 默认实现 trait作为参数 Trait Bound语法 通过指定多个 trait bound …

opengl日记12-opengl坐标系统

文章目录 环境代码CMakeLists.txtvertexShaderSource.vsmain.cpp 总结 环境 系统&#xff1a;ubuntu20.04opengl版本&#xff1a;4.6glfw版本&#xff1a;3.3glad版本&#xff1a;4.6cmake版本&#xff1a;3.16.3gcc版本&#xff1a;10.3.0 在<opengl学习日记11-opengl的t…

2024年旅游卡代理好做嘛?浅析旅游卡加盟项目的发展前景

旅游卡代理作为一种新型的旅游消费方式&#xff0c;近年来备受瞩目。其中&#xff0c;千益畅行共享旅游卡作为旅游卡代理市场的一员&#xff0c;其便捷性和实用性得到了广大消费者的认可。那么&#xff0c;旅游卡代理究竟好做吗&#xff1f;千益畅行共享旅游卡的发展前景又如何…

【Caddy】 Ubuntu 下卸载 Caddy

要在 Ubuntu 下卸载 Caddy&#xff0c;你可以按照以下步骤进行&#xff1a; 步骤一&#xff1a;停止 Caddy 服务 首先&#xff0c;停止正在运行的 Caddy 服务&#xff1a; sudo systemctl stop caddy步骤二&#xff1a;卸载 Caddy 软件包 执行以下命令卸载 Caddy 软件包&am…

【算法】差分、前缀和(重新排序)

给定一个数组 A和一些查询 Li,Ri&#xff0c;求数组中第 Li 至第 Ri个元素之和。 小蓝觉得这个问题很无聊&#xff0c;于是他想重新排列一下数组&#xff0c;使得最终每个查询结果的和尽可能地大。 小蓝想知道相比原数组&#xff0c;所有查询结果的总和最多可以增加多少? 输…

Java 什么时候类会被加载?

Java 什么时候类会被加载&#xff1f; 题目 Java 什么时候类会被加载&#xff1f; 推荐解析 1&#xff09;创建类的实例&#xff0c;也就是 new 一个对象 public class Test {public static void main(String[] args) {MyClass obj new MyClass(); // 通过new关键字实例化…

多语言LLM的状态:超越英语

多语言大语言模型的发展现状&#xff1a;超越英语 引言 据微软研究院的数据显示&#xff0c;世界上大约88%的语言&#xff0c;即12亿人的母语&#xff0c;缺乏对大型语言模型&#xff08;LLM&#xff09;的访问。这是因为大多数LLM都是以英语为中心的&#xff0c;即它们大多是…

Java:接口

目录 1.接口的概念2.接口的语法规则3.接口使用4.接口的特性5.实现多个接口6.接口中的继承7.抽象类和接口的区别 1.接口的概念 在现实生活中&#xff0c;接口的例子比比皆是&#xff0c;比如&#xff1a;笔记本上的USB口&#xff0c;电源插座等。 电脑的USB口上&#xff0c;可以…

pycorrector检测OCR错字实践

参考&#xff1a;https://github.com/shibing624/pycorrector/tree/master/examples/macbert stopwords.txt 添加专业停用词&#xff0c;避免错误 设置自定义词典&#xff0c;避免将正确的词错误检测成错误的词 from pycorrector import Corrector m Corrector() m.set_cus…

Windows系统部署GoLand结合内网穿透实现SSH远程Linux服务器开发调试

&#x1f308;个人主页: Aileen_0v0 &#x1f525;热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法|MySQL| ​&#x1f4ab;个人格言:“没有罗马,那就自己创造罗马~” #mermaid-svg-HIOuHATnug3qMHzx {font-family:"trebuchet ms",verdana,arial,sans-serif;f…

系统学习Python——装饰器:“私有“和“公有“属性案例-[为Python3.X重定义运算符重载方法的途径:内联定义]

分类目录&#xff1a;《系统学习Python》总目录 正如前面的文章所提到的&#xff0c;Python3.X中最直接的解决方案是&#xff1a;在像装饰器这样的基于委托的类中&#xff0c;重新定义可能在内嵌对象中出现的运算符重载名称。这种方法并不理想&#xff0c;因为它产生了一些代码…

把软件加入开机自启动

注意这个方法最佳效果是适用于打开软件后,关闭窗口不会停止服务 例如 nginx 1.把nginx的快捷方式放到如图所示的文件夹下 C:\Users\KIA_27\AppData\Roaming\Microsoft\Windows\Start Menu\Programs\Startup 注意KIA_27应改为你自己的用户名

一维前缀和一维差分(下篇讲解二维前缀和二维差分)(超详细,python版,其他语言也很轻松能看懂)

本篇博客讲解一维前缀和&#xff0c;一维差分&#xff0c;还会给出一维差分的模板题&#xff0c;下篇博客讲解 二维前缀和&二维差分。 一维前缀和&#xff1a; 接触过算法的小伙伴应该都了解前缀和&#xff0c;前缀和在算法中应用很广&#xff0c;不了解也没有关系&#…

24计算机考研调剂 | (研究所)北京微电子技术研究所

北京微电子技术研究所2024年考研调剂信息 调剂信息 一、招生专业 二、调剂对象 统考科目为思想政治理论、英语&#xff08;一&#xff09;、数学&#xff08;一&#xff09;&#xff1b;本科为电子科学与技术、微电子学、集成电路设计、电子信息工程、通信工程、计算机科学与…

Java Day13 多线程

多线程 1、 方式一 Thread2、实现Runnable接口3、实现 Callable接口4、与线程有关的操作方法5、线程安全问题5.1 取钱案例5.2 线程同步5.2.1 同步代码块5.2.2 同步方法5.2.3 Lock锁 6、线程池6.2 创建线程池6.2.1 使用ExecutorService创建新任务策略6.2.2 使用Executors工具类创…

3.21小题总结

第一题&#xff1a;生日蛋糕 题解&#xff1a;这题是蛋糕结构是一层一层的&#xff0c;估计很多人很快就能想到是dfs&#xff0c;但是这题的难想的点在于 你每层的状态该怎么去确定&#xff0c;你怎么来确定每层的半径和高度是多少&#xff0c;一开始我也不知很理解&#xff0…