前提
現在Djangoで、入力フォームから受け取った数値を計算し表示するアプリを作成しています。
データベースの辞書型データをpk毎に計算し表示したいです。
入力フォームからデータベースに格納するところまでは出来ていますが、そのデータをpk毎に計算し表示するところで躓いています。
実現したいこと
・DetailViewのget_context_dataメソッドでURLのpkを受け取りたい
・そのpkに紐づいたデータベースのデータを取得、計算して表示したい
現在、表示したいそのページのURLにアクセスするも、そのページが存在していないとエラーが出る状況です。
発生している問題・エラーメッセージ
Page not found (404) Request Method: GET Request URL: http://localhost:8000/stat_analyze/1/
該当のソースコード
detailページでは、Statモデルの各プレイヤーのStat詳細(total_scoreやobなど)を入力し表示させています。
stat_analyzeページで、そのStat詳細を元に計算し表示させたいのですが、そこが上手くいっていません。
StatAnalyzeクラス内の計算部分は長いので省いてあります。
urls.py
1urlpatterns = [ 2 path("detail/<int:pk>/", views.StatCreate.as_view(), name="detail"), 3 path('stat_analyze/<int:pk>/', views.StatAnalyze.as_view(), name='stat_analyze'), 4]
views.py
1class StatCreate(generic.CreateView): 2 template_name = "score/detail.html" 3 form_class = StatCreateForm 4 5 def get_context_data(self, **kwargs): 6 context = super().get_context_data(**kwargs) 7 pk = self.kwargs.get("pk") 8 person = get_object_or_404(Person, pk=pk) 9 context["person"] = person 10 stats = list(Stat.objects.filter(player=pk)) 11 context["stats"] = person 12 return context 13 14 def form_valid(self, form): 15 post = form.save(commit=False) 16 post.player_id = self.kwargs.get("pk") 17 post.save() 18 return super().form_valid(form) 19 20 def get_success_url(self): 21 pk = self.kwargs.get("pk") 22 return reverse_lazy("score:detail", kwargs={"pk": pk}) 23 24class StatAnalyze(generic.DetailView): 25 template_name = "score/stat_analyze.html" 26 model = Stat 27 28 def get_context_data(self, **kwargs): 29 context = super().get_context_data(**kwargs) 30 31 pk = self.kwargs.get("pk") 32 df = pd.DataFrame(Stat.objects.filter(player_id=pk).values()) 33 34 context["practice"] = df 35 return context
models.py
1class Person(models.Model): 2 name = models.CharField(max_length=32) 3 4 def __str__(self): 5 return f'#{self.pk} {self.name}' 6 7class Stat(models.Model): 8 player = models.ForeignKey(to=Person, verbose_name='プレイヤー', on_delete=models.PROTECT) 9 date = models.DateField(verbose_name='日付') 10 total_score = models.PositiveSmallIntegerField(verbose_name='スコア', blank=False, null=False) 11 ob = models.PositiveSmallIntegerField(verbose_name='OB', blank=True, null=True) 12 penalty = models.PositiveSmallIntegerField(verbose_name='ペナルティ', blank=True, null=True) 13 fw = models.PositiveSmallIntegerField(verbose_name='FWキープ', blank=True, null=True) 14 par_on = models.PositiveSmallIntegerField(verbose_name='パーオン', blank=True, null=True) 15 putt = models.PositiveSmallIntegerField(verbose_name='パット数', blank=True, null=True)
試したこと
stat_analyzeページで、views.pyをクラスではなくただの関数にして、player_idを1に指定してやると問題なくplayer_id=1を計算した結果が表示されました。
補足情報(FW/ツールのバージョンなど)
django=3.2.1
回答1件
あなたの回答
tips
プレビュー