2012-06-23 28 views
3

我有一个字段列表以选择不同的,就像这样:Django的查询集值()方法字段顺序与返回

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> 

回答

5

queryset.values()返回类型的字典列表,http://stardict.sourceforge.net/Dictionaries.php下载不以任何特定的顺序返回自己的物品。

如果你想要你的值的顺序,使用queryset.values_list它返回的元组列表。

(你将需要保持在一个单独的上下文变量列的列表)

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) 
相关问题