我有一个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无法正确评估。
那么做我想做的最好的方法是什么?
答案 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
。