如何在不写入/读取的情况下在Python中执行JPEG压缩

How to perform JPEG compression in Python without writing/reading(如何在不写入/读取的情况下在Python中执行JPEG压缩)
本文介绍了如何在不写入/读取的情况下在Python中执行JPEG压缩的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想直接处理压缩的JPEG图像。我知道使用PIL/Pillow,我可以在保存图像时对其进行压缩,然后回读压缩后的图像-例如

from PIL import Image
im1 = Image.open(IMAGE_FILE)
IMAGE_10 = os.path.join('./images/dog10.jpeg')
im1.save(IMAGE_10,"JPEG", quality=10)
im10 = Image.open(IMAGE_10)

但是,我希望有一种方法可以做到这一点,而不需要无关紧要的写入和读取。是否有一些带有函数的Python包可以将图像和质量编号作为输入并返回具有给定质量的图像的jpeg版本?

推荐答案

对于内存中类似文件的内容,可以使用StringIO。 看一看:

from io import StringIO # "import StringIO" directly in python2
from PIL import Image
im1 = Image.open(IMAGE_FILE)

# here, we create an empty string buffer    
buffer = StringIO.StringIO()
im1.save(buffer, "JPEG", quality=10)

# ... do something else ...

# write the buffer to a file to make sure it worked
with open("./photo-quality10.jpg", "w") as handle:
    handle.write(buffer.contents())

如果您检查photo-quality10.jpg文件,它应该是相同的图像,但质量为10%,与JPEG压缩设置相同。

这篇关于如何在不写入/读取的情况下在Python中执行JPEG压缩的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Leetcode 234: Palindrome LinkedList(Leetcode 234:回文链接列表)
How do I read an Excel file directly from Dropbox#39;s API using pandas.read_excel()?(如何使用PANDAS.READ_EXCEL()直接从Dropbox的API读取Excel文件?)
subprocess.Popen tries to write to nonexistent pipe(子进程。打开尝试写入不存在的管道)
I want to realize Popen-code from Windows to Linux:(我想实现从Windows到Linux的POpen-code:)
Reading stdout from a subprocess in real time(实时读取子进程中的标准输出)
How to call type safely on a random file in Python?(如何在Python中安全地调用随机文件上的类型?)