我正在开发一个允许用户上传演示文稿的Django网络应用程序。演示文稿需要转换为图像,每张幻灯片一个,并且图像需要作为模型的一部分保存到ImageField。但是,当我尝试将本地图像保存到模型时,Django会在图像文件的标题上抛出UnicodeDecodeError。
UnicodeDecodeError: 'utf-8' codec can't decode byte 0x89 in position 0: invalid start byte
我做了一点阅读,发现这是PNG图像文件的有效标题的一部分。似乎无论出于何种原因,Django都试图将二进制文件解码为unicode。
这是我试图将图像保存到的模型:
class PresentationSlide(models.Model):
...
image = models.ImageField(upload_to=upload_to)
upload_to
函数使用base64编码的UUID保存上传的文件。
在视图中,我验证表单,获取演示文件文件,并使用自定义库将其转换为临时目录中的单个图像。然后,我们的想法是为每个图像创建一个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文本?
答案 0 :(得分:2)
确保以二进制模式打开文件描述符。
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
。