Django 模板在 for 循环中计算总数
Django templates count total in forloop
我在 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 table 中):
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?或者完全不同的东西?
您应该使用 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 排序才能正常工作。
我在 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 table 中):
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?或者完全不同的东西?
您应该使用 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 排序才能正常工作。