我正在开发一个允许用户上传演示文稿的 Django 网络应用程序。演示文稿需要转换为图像,每张幻灯片一张,图像需要作为模型的一部分保存到 ImageField 中。但是,当我尝试将本地镜像保存到模型时,Django 在图像文件的 header 上抛出 UnicodeDecodeError。
UnicodeDecodeError:“utf-8”编解码器无法解码位置 0 中的字节 0x89:起始字节无效
我稍微阅读了一下,发现这是 PNG 图像文件的有效 header 的一部分。似乎无论出于何种原因,Django 都试图将二进制文件解码为 unicode。
这是我试图将图像保存到的模型:
class PresentationSlide(models.Model):
...
image = models.ImageField(upload_to=upload_to)
upload_to
函数使用 base64 编码的 UUID 保存上传的文件。
在 View 中,我验证表单,获取演示文稿文件,并使用自定义库将其转换为临时目录中的单个图像。然后的想法是为这些图像中的每一个创建一个 PresentationSlide 实例。
下面是我如何尝试创建模型实例并保存图像。
presentation = Presentation.objects.create(
description=form.cleaned_data['description'])
slides = [PresentationSlide.objects.create(
presentation=presentation, order=order,
duration=form.cleaned_data['slide_interval'])
for order, image in enumerate(slide_images)]
for image_path, slide in zip(sorted(slide_images), slides):
with open(image_path) as image:
slide.image.save(image.name, File(image))
是什么导致 Django 尝试将此二进制文件解码为 Unicode 文本?
最佳答案
确保以二进制模式打开文件描述符。
for image_path, slide in zip(sorted(slide_images), slides):
with open(image_path, mode='rb') as image:
slide.image.save(image.name, File(image))
默认情况下,open
将返回一个尝试解释文本的 TextIOWrapper
。
关于python - 从本地 PNG 创建 Django 文件引发 UnicodeDecodeError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43687418/