0

我希望我的模板按类别显示我的组作为标题,然后在其下按类别显示该组的所有值。例如,我的表如下所示:

['John','Physics']
['Jim','Physics']
['Sam','Biology']
['Sarah','Biology']

我希望模板输出这个:

物理

约翰

吉姆

生物学

山姆

莎拉

我不确定要在我的 veiws.py 中放入什么,因为我通常会在 SQL 中执行此操作 --> 首先按类别分组,然后返回该类别中的所有结果。

我的 veiws.py 和模板将如何完成此任务?谢谢。

我当前的 veiws.py:

def department(request):
students = Students.objects.all().order_by('department')
return render(request, 'department.html', {
    'students':students,
})

这是我的model.py

class Mentors(models.Model):
    name = models.CharField(max_length=100)
    degree = models.CharField(max_length=100)
    department = models.CharField(max_length=100)

还有我的模板:

{% if mentors %}
<div class="row">
    {% for mentor in mentors %}
            <div class="col-xs-12 col-sm-6 col-md-6 col-lg-4">
                <h3>{{ mentor.department }}</h3>
            </div>
            <div class="col-xs-12 col-sm-6 col-md-6 col-lg-4">
                <div class="thumbnail">
                    <img src="{{ mentor.image.url }}" class="img-thumbnail">
                    <div class="caption">
                        <h4 class="text-center">{{ mentor.name }}, {{ mentor.degree }}</h4>
                        <p class="text-center"><small>{{ mentor.department }}</small></p>
                    </div>
                </div>
            </div>
    {% endfor%}
</div><!-- /.end row -->
{% endif %}
4

1 回答 1

0

模板 (department.html) 是您要列出所有学生的地方。你必须有一些类似的:

{% if students %}
    {% for student in students %}
        <p>{{ student.NAME_FIELD }}</p>
        {{ student.DEPARTMENT_FIELD}}
    {% endfor %}
{% else %}
    No student are available.
{% endif %}

NAME_FIELD 和 DEPARTMENT_FIELD 是您在 model.py 中声明的字段

于 2016-09-08T17:34:57.520 回答