Django:用于为上传的图像添加字幕的Formset

时间:2013-01-16 17:41:31

标签: python django image django-forms

我正在使用Django并尝试实现,我认为,这是图像上传中相当常见的功能。我想生成formset(可能为modelformset?),为用户刚上传的每张图片添加标题(类似于“查看刚上传的图片”页面)。

这是基本想法:

我有一个简单的表格可以一次提交一个或多个图像:

class UploadImageForm(forms.Form):
    images = forms.FileField(widget=forms.ClearableFileInput(attrs={'multiple': 'multiple'}))

它产生了这个:

enter image description here

然后,在视图中,我对POST中的每个图像进行一些处理/处理,并将图像的已调整大小的版本存储为模型的实例,称为ImageItem

class ImageItem(models.Model):
    resized_img = models.ImageField(upload_to=img_get_file_path)
    user = models.ForeignKey(User)
    upload_date = models.DateTimeField(auto_now_add=True)
    last_modified = models.DateTimeField(auto_now=True)      
    caption = models.CharField(max_length=1000,
                               blank=True)

(这是UploadImage视图,仅供参考...请注意,只要表单经过验证并且图像已保存在 handle_uploaded_image 函数中,它就会重定向到查看为所有图像添加标题。)

def UploadImageToLibrary(request):
    if request.method == 'POST':
        form = UploadImageForm(request.POST, request.FILES)
        if form.is_valid():
            handle_uploaded_image(form) # creates new sizes of images, saves resized version as ImageItem instances
            return AddInfoForImage(request) # SEND USER TO A PAGE FOR ADDING CAPTIONS TO EACH IMAGE...not sure what this next view should contain...?
    else:
        form = UploadImageForm()
    return render_to_response('upload_item.html', {'form': form}, context_instance=RequestContext(request))

好的,现在我需要帮助的部分....

一旦图像保存,我希望下一个视图为每个上传的图像生成一个表单,以便用户可以为图像添加标题。当他们完成将所有信息添加到所有新图像后,他们会点击submit,并且每个标题都会保存到相应的ImageItem实例中。我不知道应该创建多少表单,这取决于用户上传了多少图像。下面是我希望formset执行的操作的可视化表示(忽略其他内容,我们可以继续使用简单的标题作为示例):

enter image description here


具体来说,这是我需要帮助的东西:

  • 根据用户刚刚上传的图片数量,我不知道如何提供适当数量的CaptionForm
  • 我不知道如何将相应的ImageItem.resized_img放在它在模板中引用的表单的左侧。
  • 我不知道如何确保提交CaptionForm后,我将字幕保存到相应的ImageItem实例。

我认为可以通过一个formsetmodelformset解决方案以某种方式解决所有这三个问题?


就像我说的,这似乎是一种非常普遍的情况。如果有人知道任何现有代码,请告诉我。谢谢!

1 个答案:

答案 0 :(得分:1)

我认为您需要使用model formsets并访问模板{{ form.instance.resized_img }}中已调整大小的图片