【问题标题】:PIL open() method not working with BytesIOPIL open() 方法不适用于 BytesIO
【发布时间】:2014-06-28 12:58:00
【问题描述】:

由于某种原因,当我尝试从 BytesIO 流中制作图像时,它无法识别图像。这是我的代码:

from PIL import Image, ImageGrab
from io import BytesIO

i = ImageGrab.grab()
i.resize((1280, 720))
output = BytesIO()
i.save(output, format = "JPEG")
output.flush()
print(isinstance(Image.open(output), Image.Image))

以及它抛出的错误的堆栈跟踪:

Traceback (most recent call last):
  File "C:/Users/Natecat/PycharmProjects/Python/test.py", line 9, in <module>
    print(isinstance(Image.open(output), Image.Image))
  File "C:\Python27\lib\site-packages\PIL\Image.py", line 2126, in open
    % (filename if filename else fp))
IOError: cannot identify image file <_io.BytesIO object at 0x02394DB0>

我正在使用 PIL 的 Pillow 实现。

【问题讨论】:

  • 你不需要 output.flush()

标签: python python-imaging-library pillow


【解决方案1】:

把 BytesIO 想象成一个文件对象,当你写完图像后,文件的光标在文件的末尾,所以当Image.open() 尝试调用output.read() 时,它会立即得到一个 EOF。

您需要在将output 传递给Image.open() 之前添加output.seek(0)

【讨论】:

  • 对于任何偶然发现此答案的人,看起来这可能已在最新版本的 BytesIO 中得到解决。我正在运行 Image.open(io.BytesIO(image_contents)) 而没有调用 seek(0) 没有问题。我遇到了类似的错误,但这是因为 image_contents 不是有效的图像数据。
  • 不,它不是“在 BytesIO 中修复的”。 BytesIO 正在按设计工作。较新版本的PIL.open() 只是无条件地调用.seek(0) (src) 以支持从HTTP 请求中读取,看起来它无意中解决了这个问题。 PIL 通过强制 .seek(0) 在这里所做的事情打破了用户想要从容器/级联档案中读取而不解压缩或制作额外副本的用例。我猜他们可能认为这个用例与 HTTP 请求对象相比相当小众。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2013-09-26
  • 2023-03-08
  • 1970-01-01
  • 1970-01-01
  • 2013-11-10
  • 1970-01-01
  • 2021-07-07
相关资源
最近更新 更多