djangoでdetail表示したものにユーザー1人1回のみのカウント機能をつけようとしたところ、下記のようなエラーが消えないのですが、どうしたら消えるのでしょうか?
python
1argument of type 'NoneType' is not iterable
python
1views.py 2def readfunc(request,pk): 3 post = Answer.objects.get(pk=pk) 4 post2 = request.user.get_username() 5 if post2 in post.reader: 6 return redirect('diary_detail') 7 else: 8 post.read += 1 9 post.reader = post.redirect + ' ' + post2 10 post.save() 11 return redirect('diary_detail') 12 13class DiaryDetailView(DetailView): 14 model = Diary 15 template_name = 'diary_detail.html' 16 17 18 19class AnView(CreateView): 20 21 model = Answer 22 fields = ( 'content','photo1') 23 template_name = 'answer.html' 24 25 def form_valid(self, form): 26 diary_pk = self.kwargs['pk'] 27 diary = get_object_or_404(Diary, pk=diary_pk) 28 29 30 answer = form.save(commit=False) 31 answer.user = self.request.user 32 answer.diary = diary 33 answer.save() 34 35 36 return redirect('ampapp:diary_detail', pk=diary_pk)
-----models.py---- class Answer(models.Model): """質問回答""" user = models.ForeignKey(CustomUser, verbose_name='ユーザー', on_delete=models.PROTECT) content = models.TextField(verbose_name='本文', blank=True, null=True) photo1 = models.ImageField(verbose_name='写真1', blank=True, null=True) photo2 = models.ImageField(verbose_name='写真2', blank=True, null=True) photo3 = models.ImageField(verbose_name='写真3', blank=True, null=True) created_at = models.DateTimeField(verbose_name='作成日時', auto_now_add=True,null=True) updated_at = models.DateTimeField(verbose_name='更新日時', auto_now=True) diary = models.ForeignKey(Diary, on_delete=models.CASCADE,null=True) reader = models.CharField(verbose_name='いいね', max_length=40,null=True) read = models.IntegerField() class Meta: verbose_name_plural = 'Answer' def __str__(self): return self.content
----diary_detail.html------ {% for answer in object.answer_set.all %} <h3>{{ answer.user }}</h3> <h4>{{ answer.content }}</h4> <a class="btn btn-primary float-right" href="{% url 'ampapp:read' object.pk %}">カウント:{{answer.read}}</a> {% endfor %}
エラー文がその箇所だけだと分かりにくいですね…。
エラー文をスクショを撮るなどして、エラーに関する情報を増やすと、回答を得られるかもしれません(`・ω・´)ゞ
回答1件
あなたの回答
tips
プレビュー