文字PDF转图片PDF,适合pdf防复制

完整代码已传至github平台:
https://github.com/yaunsine/text_pdf_to_image_pdf

分成两步操作:

1、将文字pdf输出成图片

2、将所有图片合成为pdf

将PDF文件输出为图片的形式
python 复制代码
"""
    pdf转图片
"""
def pyMuPDF_fitz(pdfPath, imagePath):
    startTime_pdf2img = datetime.datetime.now()  # 开始时间
    create_directory(".\\output_img")
    print("imagePath=" + imagePath)
    pdfDoc = fitz.open(pdfPath)
    for pg in range(pdfDoc.pageCount):
        page = pdfDoc[pg]
        rotate = int(0)
        # 每个尺寸的缩放系数为1.3,这将为我们生成分辨率提高2.6的图像。
        # 此处若是不做设置,默认图片大小为:792X612, dpi=96
        zoom_x = 1.33333333  # (1.33333333-->1056x816)   (2-->1584x1224)
        zoom_y = 1.33333333
        mat = fitz.Matrix(zoom_x, zoom_y).prerotate(rotate)
        pix = page.get_pixmap(matrix=mat, alpha=False)

        if not os.path.exists(imagePath):  # 判断存放图片的文件夹是否存在
            os.makedirs(imagePath)  # 若图片文件夹不存在就创建

        pix.save(imagePath + '/' + 'images_%s.png' % pg)  # 将图片写入指定的文件夹内

    endTime_pdf2img = datetime.datetime.now()  # 结束时间
    print('pdf2img时间=', (endTime_pdf2img - startTime_pdf2img).seconds)
将所有的图片合并成PDF
python 复制代码
"""
    合并图片成pdf
"""
def merge_img_to_pdf(path: str, name: str):
    create_directory(".\\output_pdf")
    img_open_list = []                                 # 创建打开后的图片列表
    for root, dirs, files in os.walk(path):
        for i in files:
            file = os.path.join(root, i)               # 遍历所有图片,带绝对路径
            img_open = Image.open(file)                # 打开所有图片
            if img_open.mode != 'RGB':
                img_open = img_open.convert('RGB')     # 转换图像模式
            img_open_list.append(img_open)             # 把打开的图片放入列表
    # pdf_name = name + '.pdf'                           # pdf文件名
    pdf_name = name
    img_1 = img_open_list[0]                           # 打开的第一张图片
    # 把img1保存为PDF文件,将另外的图片添加进来,列表需删除第一张图片,不然会重复
    img_open_list = img_open_list[1:]
    img_1.save(pdf_name, "PDF", resolution=100.0, save_all=True, append_images=img_open_list)
    print('转换成功!pdf文件在当前程序目录下!')
    clear_imgs(path)
相关推荐
鱼很腾apoc5 分钟前
【实战篇】 第14期 算法竞赛_数据结构超详解(下)
c语言·开发语言·数据结构·学习·算法·青少年编程
芳草萋萋鹦鹉洲哦6 分钟前
后端C#,最好能跨平台,桌面应用框架如何选择?
开发语言·c#
神奇小梵9 分钟前
c语言易错知识点
c语言·开发语言
人机与认知实验室9 分钟前
<span class=“js_title_inner“>如何看待特斯拉第三代Optimus机器人?</span>
开发语言·javascript·机器人·ecmascript·unix
Coding茶水间16 分钟前
基于深度学习的花朵识别系统演示与介绍(YOLOv12/v11/v8/v5模型+Pyqt5界面+训练代码+数据集)
开发语言·人工智能·深度学习·yolo·目标检测·机器学习
moxiaoran575339 分钟前
Go语言的文件操作
开发语言·后端·golang
我命由我1234542 分钟前
Android 开发问题:Duplicate class android.support.v4.app.INotificationSideChannel...
android·java·开发语言·java-ee·android studio·android-studio·android runtime
小白学大数据1 小时前
Python 进阶爬虫:解析知识星球 API
开发语言·爬虫·python
赴前尘1 小时前
记一次golang进程执行卡住的问题排查
开发语言·后端·golang
whale fall1 小时前
如何在同一台电脑里安装32 位 Python 和 64 位 Python
开发语言·笔记·python·学习