图像库从JPEG转换为

时间:2012-09-27 17:09:41

标签: python pdf image-processing python-imaging-library resolution

我正在尝试将带有200 dpi的JPEG文件转换为PDF文件,但是,当我将文件另存为PDF时,我认为它将dpi更改为72,从而使图像更大。我最初尝试将JPEG图像缩放到较小的尺寸时遇到了类似的问题,并且能够通过在保存图像时指定dpi来解决这个问题。

im = Image.open("Image.jpg")

dpi=im.info['dpi']

if im.size == (2592, 1728):
    out = im.resize((1188,792), Image.ANTIALIAS)
elif im.size == (1728,2592):
    out = im.resize((792,1188), Image.ANTIALIAS)

out.save(project, dpi=dpi)

现在,当我尝试将此JPEG格式保存为PDF时,指定dpi似乎没有任何区别,并且我得到的图像大于原始图像,看起来它的dpi较低。使用PIL从JPEG转换为PDF时,有没有办法保持一致的分辨率?或者我有更好的方法来做这件事吗?

这就是我将文件目录从JPEG转换为PDF的原因:

for infile in listing:

    outfile = destpath + os.path.splitext(infile)[0] + ".pdf"
    current = path + infile

    if infile != outfile:
        im = Image.open(current)
        dpi=im.info['dpi']

        im.save(outfile, "PDF", Quality = 100)

7 个答案:

答案 0 :(得分:11)

PIL 1.1.7来源的CHANGES文件中,您可以阅读:

  
      
  • 为PDF文件添加了分辨率保存选项。

         

    Andreas Kostyrka写道:我已经加入了修补过的PdfImagePlugin.py
      基于Ubuntu中包含的1.1.6,支持“解决方案”
      保存选项。不是很好,但它使得PDF节省更有用   允许不完全是72dpi的PDF。

  •   

所以你应该能够做到:

im.save(outfile, "PDF", resolution=100.0)

(似乎在我的Ubuntu盒子上工作正常)。

答案 1 :(得分:6)

您可以使用reportlab库。

import sys

from reportlab.lib.pagesizes import letter
from reportlab.platypus import SimpleDocTemplate, flowables

__jpgname = str()
def drawPageFrame(canvas, doc):
    width, height = letter
    canvas.saveState()
    canvas.drawImage(
    __jpgname, 0, 0, height, width,
    preserveAspectRatio=True, anchor='c')
    canvas.restoreState()

def jpg2pdf(pdfname):
    width, height = letter

    # To make it landscape, pagesize is reversed
    # You can modify the code to add PDF metadata if you want
    doc = SimpleDocTemplate(pdfname, pagesize=(height, width))
    elem = []

    elem.append(flowables.Macro('canvas.saveState()'))
    elem.append(flowables.Macro('canvas.restoreState()'))

    doc.build(elem, onFirstPage=drawPageFrame)

if __name__ == '__main__':
    if len(sys.argv) < 3:
    print("Usage: python jpg2pdf.py <jpgname> <pdfname>")
    exit(1)
    __jpgname = sys.argv[1]
    jpg2pdf(sys.argv[2])

答案 2 :(得分:2)

PIL参数必须小写。

  

im.save(outfile,“PDF”,质量= 100)

质量= 100 ----将无效。

答案 3 :(得分:1)

这是一个代码,可以转换任何带有.jpg或.JPG扩展名的文件并转换为pdf,然后删除已转换的图像。对不起,评论是法语。

import os #necessaire pouvoir supprimer l'image une fois converti et parcourir les fichers dans le dossier
from fpdf import FPDF #necessaire pour convertir les jpg en pdf


for file in os.listdir(): # pour chaque fichiers dans le dossier dans lequel se trouve ce fichier python
if file.endswith(".jpg") or file.endswith(".JPG"): #permet de selectionner les fichers avec l'extension .jpg ou .JPG
    img=os.path.join(file) #convertie le nom du fichier en variable
    pdf = FPDF()
    pdf.add_page()
    pdf.set_font('Arial', 'B', 16)
    pdf.image('%s'%img, 3,3,204 ) # les chiffres permettent de positionner l'image sur le pdf : 3mm de la gauche, 3mm du haut, et 204 mm de la gauche pour la fin de l'image
    img2=img[:-4] #supprime les 4 dernières lettres du nom du ficher, à savoir '.jpg' ou '.JPG'
    pdf.output('%s.pdf'%img2,'F') #convertie en pdf
    os.remove('%s'%img) #supprime les fichier jpg ou JPG

答案 4 :(得分:0)

您可能需要使用:

import PIL
import PIL.Image

filename = 'filename'
im = PIL.Image.open(filename)

newfilename = 'path.pdf'
PIL.Image.Image.save(newfilename,outfile, "PDF", resoultion = 100.0)

我使用的是Windows,我用pip来安装PIL。由于某种原因,它切换到PIL.Image.Image

答案 5 :(得分:0)

这里有一个完整的例子:

import os
import PIL.Image

def img2pdf(fname):
    filename = fname
    name = filename.split('.')[0]
    im = PIL.Image.open(filename)
    if not os.path.exists('im2pdf_output'):
        os.makedirs('im2pdf_output')
    newfilename = ''.join(['im2pdf_output/',name,'.pdf'])
    PIL.Image.Image.save(im, newfilename, "PDF", resolution = 100.0)
    print("processed successfully: {}".format(newfilename))

files = [f for f in os.listdir('./') if f.endswith('.jpg')]
for fname in files:
    img2pdf(fname)

答案 6 :(得分:-1)

保存的正确用法是:

PIL.Image.Image.save(im, newfilename, "PDF", resolution = 100.0)

示例:

path='v:/dev/python/mooc/'
filename = path + '2016_a_milano_001.JPG'
im = PIL.Image.open(filename)
newfilename = path+ 'r.pdf'
PIL.Image.Image.save(im, newfilename, "PDF", resoultion=100.0)