django queryset values()方法字段顺序与返回的不同

时间:2012-06-23 09:45:31

标签: python django django-queryset

我有一个字段列表可供选择,如下所示:

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>

2 个答案:

答案 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)