我的视图代码基本上是这样的:在Django模板中通过变量访问字典?
context = Context()
context['my_dict'] = {'a': 4, 'b': 8, 'c': 15, 'd': 16, 'e': 23, 'f': 42 }
context['my_list'] = ['d', 'f', 'e', 'b', 'c', 'a']
什么,我想在我的Django的模板做的是这样的:
<ul>
{% for item in my_list %}
<li>{{ item }} : {{ my_dict.item }}</li>
{% endfor %}
</ul>
,我想这是输出:
<ul>
<li> d : 16 </li>
<li> f : 42 </li>
<li> e : 23 </li>
<li> b : 8 </li>
<li> c : 15 </li>
<li> a : 4 </li>
</ul>
但是,通过{{ my_dict.item }}
通过变量名称引用字典实际上并不起作用。我怀疑它是在内部做my_dict['item']
而不是my_dict[item]
。有什么办法可以解决这个问题吗?
当然,我总是可以在视图中说,添加更多的代码:背景[ 'my_derefernced'] = [(V,上下文[my_dict] [V])为以V context ['my_list']]但我宁愿不必这样做。这些指令可能相当大。 – slacy 2010-01-14 19:50:05
看看这个伟大的解决方案:http://stackoverflow.com/questions/35948/django-templates-and-variable-attributes – fiatjaf 2012-01-01 15:26:24
如果字迹很大,为什么不使用生成器?可能是这样的:'context ['my_dereferenced'] =((v,context [my_dict] [v])for context ['my_list'])' – user193130 2015-03-20 17:25:52