Djangoを初めて使用しましたが、ModelFormを使用した画像のアップロードの処理で問題が発生しました。私のモデルは次のとおりです:
class Project(models.Model):
name = models.CharField(max_length=100)
description = models.CharField(max_length=2000)
startDate = models.DateField(auto_now_add=True)
photo = models.ImageField(upload_to="projectimg/", null=True, blank=True)
そして、modelformは次のとおりです。
class AddProjectForm(ModelForm):
class Meta:
model = Project
widgets = {
'description': Textarea(attrs={'cols': 80, 'rows': 50}),
}
fields = ['name', 'description', 'photo']
そして、ビュー関数は:
def addProject(request, template_name):
if request.method == 'POST':
addprojectform = AddProjectForm(request.POST,request.FILES)
print addprojectform
if addprojectform.is_valid():
newproject = addprojectform.save(commit=False)
print newproject
print request.FILES
newproject.photo = request.FILES['photo']
newproject.save()
print newproject.photo
else:
addprojectform = AddProjectForm()
newProposalNum = projectProposal.objects.filter(solved=False).count()
return render(request, template_name, {'addprojectform':addprojectform,
'newProposalNum':newProposalNum})
テンプレートは次のとおりです。
<form class="bs-example form-horizontal" method="post" action="">{% csrf_token %}
<h2>Project Name</h2><br>
{{ addprojectform.name }}<br>
<h2>Project Description</h2>
{{ addprojectform.description }}<br>
<h2>Image Upload</h2><br>
{{ addprojectform.photo }}<br>
<input type="submit" class="btn btn-success" value="Add Project">
</form>
誰かが私を助けてくれますか、または画像のアップロードの例を挙げていただけますか?ありがとうございました!
わかりました、みんなに感謝します。私は愚かな間違いをした。追加する必要がありますenctype="multipart/form-data"
の中に <form>
そうでない場合、ファイルはアップロードされません。
_newproject.photo
_を_request.FILES['photo']
_に設定する必要はありません(実際には、これはおそらくここでコードを壊します)。 addprojectform.save()
の代わりにnewproject = addprojectform.save(commit=False)
を使用してaddprojectform
を保存するだけです。詳細はこちら: https://docs.djangoproject.com/en/1.5/topics/http/file-uploads/#handling-uploaded-files-with-a-model