我正在尝试将带有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)
答案 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)