0

我正在尝试在 django 模板页面上显示调查结果。我无法根据特定的人口统计数据和每个类别的评分来显示平均值。我已经将调查响应数据以整数形式保存在我拥有的调查表单视图中。这是我到目前为止剩下的:

#views.py
def statistics(request):
    male = Survey.objects.filter(gender='male')
    ...
    #Other demographics filtered
    ...

    def avgcalc(myDemographic, myCategory):
        ratings = []

        for x in myDemographic:
            ratings.append(myCategory)

        intTotal = 0
        intCount = 0
        intLenMyList = len(myDemographic)

        while(intCount <  intLenMyList):
            intTotal += ratings[intCount]
            intCount += 1

        return intTotal/intLenMyList
...
#rest of view rendering template, etc.

现在是我遇到问题的地方。如何根据人口统计轻松显示每个类别的数据?例如,在我的模板中我想做

#template.html
Demographic: Male
Total responses for this demographic: {{ male|length }}
Average response for specific category: {{ avgcalc(male, category) }}

{{ male|length }} 可以很好地显示男性受访者的数量,但是,在模板中,我不能使用 {{ avgcalc(male, category) }}。实际上,我已经设置了一个表格,并且大约有 20 个人口统计数据和十几个类别评级,所以如果可能的话,我希望避免将每一个都放在我的视图中(即 male_category_calc = avgcalc(male, category)对于每个人口统计和类别。这甚至可能吗,或者我需要做很长的路吗?只要它有效,我可以将每一个输入到我的模板中。感谢任何帮助或建议。

4

2 回答 2

0

您可以使用 django 的自定义模板标签来做到这一点。

要计算平均值,您可能需要查看 django 的聚合

它们具有 Avg 函数来计算特定字段的平均值。(在您的情况下是类别)

from django.db.models import Avg
Model.objects.all().aggregate(Avg('attribute'))
于 2012-11-05T18:26:23.340 回答
0

您可以使用自定义模板标签或过滤器扩展模板功能。像这个:

foo_app/templatetags/foo_tags.py:

from django import template
register = template.Library()

@register.filter
def avgcalc(myDemographic, myCategory):
    ratings = []

    for x in myDemographic:
        ratings.append(myCategory)

    intTotal = 0
    intCount = 0
    intLenMyList = len(myDemographic)

    while(intCount <  intLenMyList):
        intTotal += ratings[intCount]
        intCount += 1

    return intTotal/intLenMyList

然后在你的template.html中:

{% load foo_tags %}

{{ male|avgcalc:category }}
于 2012-11-05T17:34:19.653 回答