我在Django模板中有以下代码。
{% if levels %}
{% for l in levels %}
<tr>
<td class="level">{{ l.skill }}</td>
{% for e in employees %}
{% if e.skill_level_id == l.id %}
<td class="race">{{ forloop.counter0 }}</td>
{% endif %}
{% endfor %}
</tr>
{% endfor %}
{% endif %}
这给了我类似以下内容(在HTML表格中):
level1 1 5
level2 4 2 6 3
这意味着1级(1和5)的2名员工和2级的4名员工。我想要的是每个级别的总数:
level1 2
level2 4
我不确定是否应该使用forloop.counter,forloop.counter0或forloop.parentloop.counter?还是完全不同的东西?
答案 0 :(得分:4)
您应该使用regroup
将对象分组到技能级别,而不是循环和过滤。类似的东西:
{% regroup employees by skill_level as employees_by_level %}
{% for level in employees_by_level %}
<tr>
<td class="level">{{ level.grouper.skill }}</td>
<td class="count">{{ level.list|length }}</td>
{% for e in level.list %}
<td class="race">{{ forloop.counter0 }}</td>
{% endfor %}
</tr>
{% endfor %}
请注意,您需要让员工按照skill_id进行排序才能使其正常工作。