質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

447閲覧

djnagoで1人のUSERが、同じ映画に対して複数のレビューを書けないようにしたい

hiei1

総合スコア52

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2022/07/15 02:55

編集2022/07/15 02:58

実現したいこと

1人のUSERが、同じ映画に対して複数のレビューを書けないようにしたいです。
映画の情報はTMDBから持ってきているため変更をどのようにすればいいかわからず質問しました。

現状のコード

views.py

1def view_movie_detail(request, movie_id): 2 if not(Movie.objects.filter(id=movie_id)): 3 Movie(id = movie_id).save() 4 movie = Movie.objects.get(id=movie_id) 5 if request.method == "POST": 6 form = Comment_movie_CreateForm(request.POST) 7 if form.is_valid(): 8 Comment_movie( 9 comment = form.cleaned_data['comment'], 10 user = request.user, 11 stars = form.cleaned_data['stars'], 12 movie = movie 13 ).save() 14 return redirect('view_movie_detail', movie_id=movie_id) 15 else: 16 form = Comment_movie_CreateForm() 17 data = requests.get(f"https://api.themoviedb.org/3/movie/{movie_id}?api_key={TMDB_API_KEY}&language=en-US") 18 recommendations = requests.get(f"https://api.themoviedb.org/3/movie/{movie_id}/recommendations?api_key={TMDB_API_KEY}&language=en-US") 19 comments = reversed(Comment_movie.objects.filter(movie_id=movie_id)) 20 average = movie.average_stars() 21 context = { 22 "data": data.json(), 23 "recommendations": recommendations.json(), 24 "type": "movie", 25 "comments": comments, 26 "average" : average, 27 "form": form, 28 } 29 return render(request, "Movie/movie_detail.html", context)

models.py

1class Movie(models.Model): 2 id = models.CharField(primary_key=True, editable=False, 3 validators=[alphanumeric],max_length = 9999) 4 def get_comments(self): 5 return Comment_movie.objects.filter(movie_id=self.id) 6 7 def average_stars(self): 8 comments = self.get_comments() 9 n_comments = comments.count() 10 11 if n_comments: 12 return sum([comment.stars for comment in comments]) / n_comments 13 else: 14 return 0 15class Comment_movie(models.Model): 16 class Meta: 17 unique_together = ('user', 'movie',) 18 19 comment = models.TextField(max_length=1000) 20 stars = models.FloatField( 21 blank=False, 22 null=False, 23 default=0, 24 validators=[MinValueValidator(0.0), 25 MaxValueValidator(10.0)] 26 ) 27 28 user = models.ForeignKey(CustomUser, on_delete=models.CASCADE) 29 movie = models.ForeignKey(Movie, on_delete=models.CASCADE) 30 created_at = models.DateTimeField(default=datetime.now) 31 updated_at = models.DateTimeField(auto_now=True)

質問したこと

現状のコードからどのように変更すれば1つの映画に1つのコメントができるようになるでしょうか?
そして、更新や削除を追加するにはどのようにすればいいでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

Comment_movie.objects.filter(user=request.user, movie=movie_id)

でNoneなら初めてのコメントってことで処理すればいいのではないでしょうか

投稿2022/07/16 07:28

tatamyiwathy

総合スコア1039

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hiei1

2022/07/16 07:59

どこに追加すればいいでしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問