工作中需要将众多图片转换为PDF文件,在线的各种工具又感觉不是很安全,于是就想到用python写一个小工具,
完成批量图片转换PDF功能。
主要使用python的fitz插件,通过在命令行输入pip install fitz完成安装,由于该资源比较大,建议对python的下载源
进行更改,安装过程有报错,不过不影响使用。更改方式参照:
windows下,在user目录中创建一个pip目录,如C:\Users\xx\pip,新建文件pip.ini,内容如下:
[global]
index-url = http://mirrors.aliyun.com/pypi/simple/
[install]
trusted-host=mirrors.aliyun.com
功能实现代码:
#!/usr/local/python3.8.1
# coding: utf-8
# author: kanong2020
import os
import glob
import fitz
# 防止字符串乱码
os.environ['NLS_LANG'] = 'SIMPLIFIED CHINESE_CHINA.UTF8'
def frompic2pdf(img_path, pdf_path, pdf_name):
# print(img_path + pdf_name + '.jpg')
# 使用glob读图
for img in sorted(glob.glob(img_path + pdf_name + '.jpg')):
# 打开空文档
doc = fitz.open()
# 打开指定图片
imgdoc = fitz.open(img)
# 使用图片创建单页的PDF
pdfbytes = imgdoc.convertToPDF()
imgpdf = fitz.open("pdf", pdfbytes)
# 将当前页写入文档
doc.insertPDF(imgpdf)
# 保存为指定名称的PDF文件
doc.save(pdf_path + pdf_name + '.pdf')
# 关闭
doc.close()
if __name__ == '__main__':
# 读取图片地址
img_path = r'D:\test\\'
# 即将生成的pdf的目标地址
pdf_path = r'D:\test\\'
for root, dirs, files in os.walk(img_path):
for file in files:
# 目标文件名称 无后缀
destfileName = os.path.splitext(file)[0]
# print(destfileName)
frompic2pdf(img_path=img_path, pdf_path=pdf_path, pdf_name=destfileName)
运行测试验证结果,在指定目录下形成同名的pdf文件:
用文字记录生活片段