我有一个字段列表可供选择,如下所示:
field_names = [u'name', u'mobile', u'address', u'email', u'sex']
使用以下内容渲染模板:
return render_to_string('templatetags/index.html', {
'objects':User.objects.all().values(*field_names)
})
但返回的结果字段顺序与输入字段顺序不同:
带有{{objects}}的模板中的输出:
{u'mobile': u'18680868047', u'email': u'', u'sex': u'U', u'name': u'\u4f55\u667a\u5f3a', u'address': u'\u8944\u9633\u5357\u8def175\u53f7 \u73af\u4e2d\u5546\u53a6 410\u5ba4'}
这是我的模板:
<table>
{% for object in objects %}
<tr>
{% for key,value in object.items %}
<td class="{{key}}">{{ value }}</td>{% endfor %}
</tr>
{% endfor %}
</table>
答案 0 :(得分:5)
queryset.values()
返回一个dicts列表,而dicts不会以任何特定顺序返回其项目。
如果您想按顺序排列值,请使用queryset.values_list
返回元组列表。
(您需要将列列表保存在单独的上下文变量中)
答案 1 :(得分:0)
我正在使用OrderedDict集合对象来解决字段排序问题。
objects_list = []
for row in queryset:
ordered_dict = collections.OrderedDict()
for col in self.field_names:
ordered_dict[col] = row[col]
objects_list.append(ordered_dict)