2017-08-30 53 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