批量图片存为同一个pdf

Posted 勇敢起来 站起来

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了批量图片存为同一个pdf相关的知识,希望对你有一定的参考价值。

原文链接:https://blog.csdn.net/zhezhebie/article/details/88847458

 

python将图片转换为pdf,代码如下:

from reportlab.pdfgen import canvas
from reportlab.lib.units import inch, cm
from reportlab.lib.pagesizes import letter
from reportlab.platypus import SimpleDocTemplate, Paragraph, Image, PageBreak
from reportlab.lib.pagesizes import A4,A3,A2,A1, legal, landscape
from reportlab.lib.utils import ImageReader
import PIL.Image,PIL.ExifTags
from os import listdir
import os,re
import time
from reportlab.lib.units import inch

def img_search(mypath, filenames):
    for lists in os.listdir(mypath):
        path = os.path.join(mypath,lists)
        if os.path.isfile(path):
            expression = r‘[w]+.(jpg|png|jpeg)$‘
            if re.search(expression, path, re.IGNORECASE):
                filenames.append(path)
        elif os.path.isdir(path):
            img_search(path, filenames)


def img_search1(mypath, filenames):
    for lists in os.listdir(mypath):
        path = os.path.join(mypath,lists)
        if os.path.isfile(path):
            a = path.split(‘.‘)
            if a[-1] in [‘jpg‘, ‘png‘, ‘JPEG‘]:
                filenames.append(path)
        elif os.path.isdir(path):
            img_search1(path,filenames)


def rotate_img_to_proper(image):
    try:
        # image = Image.open(filename)
        if hasattr(image, ‘_getexif‘):  # only present in JPEGs
            for orientation in PIL.ExifTags.TAGS.keys():
                if PIL.ExifTags.TAGS[orientation] == ‘Orientation‘:
                    break
            e = image._getexif()  # returns None if no EXIF data
            if e is not None:
                #log.info(‘EXIF data found: %r‘, e)
                exif = dict(e.items())
                orientation = exif[orientation]
                # print(‘found, ‘,orientation)

                if orientation == 3:
                    image = image.transpose(Image.ROTATE_180)
                elif orientation == 6:
                    image = image.transpose(Image.ROTATE_270)
                elif orientation == 8:
                    image = image.rotate(90,expand=True)
    except:
        pass
    return image


def main(src_folder=None):
    output_file_name = ‘out.pdf‘
    #save_file_name = ‘ex.pdf‘
    #doc = SimpleDocTemplate(save_file_name, pagesize=A1,
    #                     rightMargin=72, leftMargin=72,
    #                     topMargin=72, bottomMargin=18)
    imgDoc = canvas.Canvas(output_file_name)#pagesize=letter
    imgDoc.setPageSize(A4)
    document_width,document_height = A4
    if src_folder is None: mypath = input(‘Input the image folder please:‘)
    else: mypath = src_folder
    filenames=[]
    start = time.clock()
    img_search(mypath, filenames)
    end = time.clock()
    print(‘find file cost time: ‘, end-start, ‘find files: ‘, len(filenames))
    # for f in filenames:
    #     print(f)
    for image in filenames:
        try:
            image_file = PIL.Image.open(image)
            image_file = rotate_img_to_proper(image_file)

            image_width, image_height = image_file.size
            print(‘img size:‘, image_file.size)
            if not(image_width>0 and image_height>0):
                raise Exception
            image_aspect = image_height/float(image_width)
            #Determins the demensions of the image in the overview
            print_width  = document_width
            print_height = document_width*image_aspect
            imgDoc.drawImage(ImageReader(image_file),document_width-print_width,
                         document_height-print_height,width=print_width,
                             height=print_height,preserveAspectRatio=True)
            #inform the reportlab we want a new page
            imgDoc.showPage()
        except Exception as e:
            print(‘error:‘,e,image)
    imgDoc.save()
    print(‘Done‘)


if __name__ == ‘__main__‘:
    main(src_folder=‘C:\Users\Administrator\Desktop\L1-U5-L3‘);

  

 
  • 1技术图片

有个问题,转换成pdf后,体积变非常大.只是测试了一下.图片32张,单张图片100kb左右,加起来3M左右,但是转换完pdf之后pdf文件有26M,这是不能接受的.

 

 

 

以上是关于批量图片存为同一个pdf的主要内容,如果未能解决你的问题,请参考以下文章

word另存为pdf图片模糊

如何把html转化为图象

Word 批量转 PDF脚本

Word 批量转 PDF脚本

Word 批量转 PDF脚本

word批量转pdf文件快捷方法。