Мой проект написан на Python 3.6.2. Я пытаюсь определить, стоит ли вообще загружать изображения (если они имеют определенное соотношение сторон), читая только заголовок (первые ~ 100 байт онлайн-файла), пока просто тестирую с помощью imghdr и Pillow.
Image.open завершается с ошибкой:
Файл "C:\Program Files"
(x86)\Python36-32\lib\site-packages\PIL\Image.py", строка 2349, в open
% (имя файла, если имя файла иначе fp))
Ошибка ОС: невозможно идентифицировать файл изображения
Я нашел примечания к выпуску 2.8 .0 для Pillow, что, казалось, предполагало, что я смогу использовать Image.open(requests.raw). Я предположил, что смогу повторно использовать уже загруженный заголовок после того, как убедился, что сбросил его с помощью search(0).
Другие ответы с этой ошибкой, похоже, связаны с сохранением буфер изображения в реальный файл, чего я пытаюсь избежать (просто повторно использую загруженные байты из response.raw для всех моих тестов/проверок и не делаю несколько запросов на загрузку на какой-либо сервер.)
Пожалуйста, где я ошибаюсь?
Вот мой пример кода:
import requests
from PIL import Image
import imghdr
import io
if __name__ == '__main__':
url = "https://ichef-1.bbci.co.uk/news/660/cps ... 060154.jpg"
try:
response = requests.get(url, stream=True)
if response.status_code == 200:
response.raw.decode_content = True
# Grab first 100 bytes as potential image header
header = response.raw.read(100)
ext = imghdr.what(None, h=header)
print("Found: " + ext)
if ext != None: # Proceed to other tests if we received an image at all
header = io.BytesIO(header)
header.seek(0)
im = Image.open(header)
im.verify()
# other image-related tasks here
else:
print("Received error " + str(response.status.code))
except requests.ConnectionError as e:
print(e)
Подробнее здесь: https://stackoverflow.com/questions/454 ... -while-try
Ошибка OS: невозможно идентифицировать файл изображения <_io.BytesIO объект по адресу 0x02F41960> при попытке повторно и ⇐ Python
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение