ユーザーIDに基づいて統計を集計するテーブルを作成しようとしています。これは初めての質問ですので、何か大事なことがないと私に負担してください。ここでDjango集計合計を計算する
は、モデルである:ここでは
class Batting(models.Model):
player = models.ForeignKey(
'Player',
on_delete=models.CASCADE,
null=True,
)
game = models.ForeignKey(
'Game',
on_delete=models.CASCADE,
null=True,
blank=True,
)
season = models.ForeignKey(
'Season',
on_delete=models.CASCADE,
null=True,
)
games_played = models.IntegerField(
blank=True,
default=1,
)
plate_appearances = models.IntegerField(
blank=True,
default=0,
)
at_bats = models.DecimalField(
default=0,
max_digits=6,
decimal_places=3,
)
hits = models.DecimalField(
blank=True,
max_digits=6,
decimal_places=3,
default=0,
)
...
batting_average = models.DecimalField(
max_digits=6,
decimal_places=3,
editable=False,
null=True
)
slugging_percentage = models.DecimalField(
max_digits=6,
decimal_places=3,
editable=False,
null=True
)
on_base_percentage = models.DecimalField(
max_digits=6,
decimal_places=3,
editable=False,
null=True
)
on_base_plus_slugging_percentage = models.DecimalField(
max_digits=6,
decimal_places=3,
editable=False,
null=True
)
def save(self, *args, **kwargs):
self.total_bases = self.singles + (self.doubles * 2) + (self.triples * 3) + (self.home_runs * 4)
self.extra_base_hits = self.doubles + self.triples + self.home_runs
self.batting_average = float(self.hits)/float(self.at_bats)
self.slugging_percentage = self.total_bases/float(self.at_bats)
self.on_base_percentage = (self.hits + self.base_on_balls + self.hit_by_pitch)/float(self.at_bats + self.base_on_balls + self.sacrifice_flys + self.hit_by_pitch)
self.on_base_plus_slugging_percentage = (self.hits + self.base_on_balls + self.hit_by_pitch)/float(self.at_bats + self.base_on_balls + self.sacrifice_flys + self.hit_by_pitch)
super(Batting, self).save(*args, **kwargs)
class Meta:
verbose_name = u'Batting Stat'
verbose_name_plural = u'Batting Stats'
def __unicode__(self):
return self.player.last_name
は図である。
def stats(request):
batting_stats = Batting.objects.values('player__id').annotate(
fn=F('player__first_name'),
ln=F('player__last_name'),
total_hits=Sum(('hits'),output_field=FloatField()),
total_at_bats=Sum(('at_bats'),output_field=FloatField()),
avg=Avg('batting_average'),
slg=Avg('slugging_percentage'),
obp=Avg('on_base_percentage'),
ops=Avg('on_base_plus_slugging_percentage'),
)
return render(request, 'stats.html', {
'batting_stats': batting_stats,
})
私が遭遇した問題は、AVG、SLG、OBP、およびOPSは、モデル内のすべての計算であるということですビュー内で平均化することは、プレーヤーIDに基づいて集計される合計を計算するのではなく、平均を平均化することです。
私は集計関数を利用しようとしましたが、動作させる方法が見つかりませんでした。 AnnotateとAggregateを組み合わせて1つのPlayer IDで統計情報を統合し、同じ計算を合計に適用する方法はありますか?
これは本当に似たような回答です。私は昨晩友人と話した話から得たものですから、私はあなたの例の助けを借りてそれにアプローチする方法を知っていると思います。 – whob13