繁体   English   中英

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

[英]How to combine a QuerySet and a Dictionary in Django Template?

我有一个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中具有匹配的User条目的那些mList应该与uList中的匹配值一起出现。

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

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

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

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

不幸的是,您不能使用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 -->

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

您认为:

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

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM