2017-08-30 56 views
1

好吧,这里是交易。我正在研究这个网络应用程序,它可以让您创建啤酒的用户,啤酒和评论。获取不同模型实例的用户输入评分的平均值(Django)

models.py:

from django.db import models 
from django.conf import settings 

class BeerModel(models.Model): 

    user = models.ForeignKey(User, default=1) 
    name = models.CharField(max_length=254, default="") 
    style = models.CharField(max_length=254, default="") 
    ibu = models.IntegerField(default="") 
    calories = models.IntegerField(default="") 
    abv = models.IntegerField(default="") 
    location = models.CharField(max_length=254, default="") 

    class Meta: 
     verbose_name_plural = 'Beers' 

    def __str__(self): 
     return self.name 

    def avg(self): 
     return 


class RateModel(models.Model): 

    FIVE_REVIEWS = (
     ('5', '5'), 
     ('4', '4'), 
     ('3', '3'), 
     ('2', '2'), 
     ('1', '1'), 
    ) 

    TEN_REVIEWS= (
     ('10', '10'), 
     ('9', '9'), 
     ('8', '8'), 
     ('7', '7'), 
     ('6', '6'), 
     ('5', '5'), 
     ('4', '4'), 
     ('3', '3'), 
     ('2', '2'), 
     ('1', '1'), 
    ) 

    user = models.ForeignKey(User, default=1) 
    beer = models.ForeignKey(BeerModel) 
    aroma = models.PositiveIntegerField(max_length=2, choices=FIVE_REVIEWS, default="5") 
    appearance = models.PositiveIntegerField(max_length=2, choices=FIVE_REVIEWS, default="5") 
    taste = models.PositiveIntegerField(max_length=2, choices= TEN_REVIEWS, default= "10") 

    class Meta: 
     verbose_name_plural = 'Ratings' 

    def __str__(self): 
     return str(self.beer) 

正如你所知道的,你可以创建使用不同的用户不同的啤酒进行审查。

我的目标是让django输出HTML,每种啤酒的“香气,外观和品味”的“平均”值。

这是我在我的views.py:

@login_required 
def home(request): 
    beers = BeerModel.objects.order_by('name') 
    rates = RateModel.objects.order_by('user') 
    avg = RateModel.objects.aggregate(aroma = Avg('aroma'), appearance = Avg('appearance'), taste = Avg('taste')) 
    dict = {'records': beers, 'rates': rates, 'avg': avg} 

    return render(request, 'beer_tracker/home.html', context=dict) 

这就是我对我的Home.html:

<h2>Overall Rating</h2> 
    {% for beers in records %} 
     <div class="table"> 
      <h4><b>Beer's Overall Ratings: </b>{{ beers.name}}</h4> 
      <ul> 
       <li><b>Aroma: </b>{{ avg.aroma }}</li> 
       <li><b>Appearance: </b>{{ avg.appearance }}</li> 
       <li><b>Taste: </b>{{ avg.taste }}</li> 
      </ul> 
     </div> 
    {% endfor %} 

不幸的是,正如你所知道的,我得到的所有啤酒的平均值。我需要每种特定啤酒的平均值。

所以,如果我有一个啤酒,让我们说蓝月亮,我有2个用户提供2条

用户1 香气:3, 外观:3, 味:8,

用户2 香气:5, 外观:5, 味:10,

我想获得蓝月亮:

阿罗ma:4, 外观:4, 口味:9,

但仍保持其他啤酒的评论值独立。

谢谢你的时间。

安东尼

+0

我需要在我的RateModel中创建一个方法,还是应该在我的views.py中创建一个函数? – Anthony

回答

1

而不是使用总的,你应该用平均数来注解你的啤酒查询集。

from django.db.models import Avg 

beers = BeerModel.objects.order_by('name').annotate(
    avg_aroma=Avg('ratemodel__aroma'), 
    avg_appearance=Avg('ratemodel__appearance'), 
    avg_taste=Avg('ratemodel__taste'), 
) 

然后,当循环浏览啤酒queryset时,您可以访问带注释的字段。

{% for beer in beers %} 
{{ beer.avg_aroma }} 
{{ beer.avg_appearance} } 
{{ beer.avg_taste }} 
{% endfor %} 

有关更多示例,请参阅joins and aggregates的文档。

+0

非常感谢。这工作。我花了几天的时间来弄清楚这个问题。 – Anthony