如何在Django模板中组合QuerySet和Dictionary?

时间:2013-10-23 22:03:50

标签: python django django-templates

我有一个Django模型对象,如下所示:

class myObj(models.Model):
    A = models.TextField()
    B = models.DateField()      
    C = models.ForeignKey(User)

我正在获取myObjs的querySet,如下所示:

mList = myObj.objects.all()

我还有一个用户字典,如下所示:

uDict = {1: "Hello", 2: "World"}  //The keys of this dictionary correspond to the field myObj.C

在我看来,我使用上下文将mList和uList发送到我的HTML模板。

在我的模板中,我想在单独的行中列出所有mLists。那些在uDict中具有匹配用户条目的mLists应该与uList中的匹配值一起出现。

我该怎么做?在模板中,我可以轻松地遍历mList。但我不知道如何将myObj.C与uDict键匹配。我知道这不会起作用:

{% for currObj in mList %}
    {{currObj.A}} {{currObj.B}} {{uDict.currObj.C}}
{% endfor %} 

...因为uDict.currObj.C无法正确评估。

那么做我想做的最好的方法是什么?

2 个答案:

答案 0 :(得分:1)

不幸的是,你不能使用for循环变量作为Django中字典的键。

您可以做的是将它们全部打包在某些列表或其他数据集中。像这样:

mList = myObj.objects.all()
uDict = {1: "Hello", 2: "World"}

data_for_template = []
for i in range(len(mList)):
    data_for_template.append(
        {
            'mListObjA':mList.A,
            'mListObjB':mList.B,
            'uDictObj':uDict[i], # or i+1 for your example uDict
        }
    )

然后在您的模板中,您将能够以类似的方式访问此数据。

{% for item in data_for_template %}
    {{item.mListObjA}} {{item.mListObjB}} {{item.uDictObj}}
{% endfor %}

基本上,您应该尝试为views.py文件中的数据执行大部分准备工作,以简化模板中的辅助功能。

修改

根据你的评论我会尝试下一步:

views.py:

mList = myObj.objects.all()
uDict = {1: "Hello", 2: "World"}

data_for_template = []
for i in range(len(mList)):
    data_for_template.append(
        {
            'mListObj':mList,
            'uDictObj':uDict[i], # or i+1 for your example uDict
        }
    )

HTML

{% for item in data_for_template %}
    {{item.mListObj.A}} {{item.mListObj.B}} {{item.uDictObj}}
    {{item.mListObj.C.F.G}}
{% endfor %}

{{data_for_template.N.mListObj.C.F.G}} <!-- Where N is the index of whatever Object you wish to access -->

答案 1 :(得分:0)

我认为最简单的方法是将uDict值直接添加到视图中的myObj个实例中。这将在上下文中为您提供列表而不是qs,但这不会对您的模板产生任何影响。

在您看来:

mList = myObj.objects.all()
for my_obj in mList:
    my_obj.user = uDict.get(my_obj.C)

这会将用户值添加到内存中实例,因此在模板中您可以获得currObj.user