我不确定迭代嵌套字典的最有效方法是为每个日期打印每个水果的总值和良好值的矩阵。以下面的两个列表和字典为例:
fruits = ['apples','oranges','bananas']
harvest_dates = ['2011-07-23','2011-07-22','2011-07-21']
harvest_data = {
'apples': {
'2011-07-23': {
'total': 100,
'good': 80},
'2011-07-22': {
'total': 97,
'good': 92},
'2011-07-21': {
'total': 90,
'good': 85}
},
'oranges': {
'2011-07-23': {
'total': 86,
'good': 82},
'2011-07-22': {
'total': 90,
'good': 75},
'2011-07-21': {
'total': 92,
'good': 92}
},
'bananas': {
'2011-07-23': {
'total': 10,
'good': 9},
'2011-07-22': {
'total': 12,
'good': 11},
'2011-07-21': {
'total': 9,
'good': 9}
}
}
我可以在python中轻松完成:
for fruit in fruits:
for day in harvest_dates:
print "harvest: %s" % harvest_data[fruit][day]['total']
print "good crop: %s" % harvest_data[fruit][day]['good']
但我不知道如何在django模板中访问这些数据。我一直在尝试这样的事情:
{% for fruit in fruits %}
...
{% for day in harvest_dates %}
...
{{ harvest_data.fruit.day.total }}
{{ harvest_data.fruit.day.good }}
...
{% endfor %}
{% endfor %}
但它根本不起作用。
{% for fruit in fruits %}
{{ harvest_data.fruit }} <--- this does not exist
{{ harvest_data[fruit] }} <--- this does not work
{% endfor %}
我是一个完全的业余爱好者,我可能认为这一切都错了,但我已经谷歌了很多,而且我不清楚获得我想要的数据的最佳方法是什么。
答案 0 :(得分:34)
由于您熟悉python,以下是逻辑上您希望在Django模板中迭代字典的方法:
for key,value in harvest_data.items():
... print key
... for key2,value2 in value.items():
... print key2
... for key3,value3 in value2.items():
... print "%s:%s"%(key3,value3)
在您的模板中,翻译如下:
{% for key, value in harvest_data.items %}
{{ key }} <br>
{% for key2,value2 in value.items %}
{{ key2 }} <br>
{% for key3, value3 in value2.items %}
{{ key3 }}:{{ value3 }} <br>
{% endfor %}
{% endfor %}
{% endfor %}
Django文档实际上简要地包含了在描述for
模板标记如何工作时如何遍历字典的示例:
https://docs.djangoproject.com/en/dev/ref/templates/builtins/#for
答案 1 :(得分:7)
滚石说这是在模板中迭代字典的方式,我只会在每次迭代中更改不同关键字的键值关键字,如下所示:
{% for key, value in harvest_data.items %}
{{ key }} <br>
{% for key2,value2 in value.items %}
{{ key2 }} <br>
{% for key3, value3 in value2.items %}
{{ key3 }}:{{ value3 }} <br>
{% endfor %}
{% endfor %}
{% endfor %}
仅为了清晰起见:)
如果您想排列您的值,我建议您使用另一种数据结构,您可以按日期排序,例如:
{ 'oranges' : [(date1, value1), (date2,value2)] ...}
尝试在模板中进行尽可能少的操作,所以如果你不需要那么不要进行排序或嵌套
答案 2 :(得分:1)
真的很老问题,但我会加上我的1.5c。
这是regroup标记(https://docs.djangoproject.com/en/1.9/ref/templates/builtins/#regroup)的一个很好的用例和一些数据重构:
将您的数据作为简单的数据点列表:
harvest_data = [
{'fruits': 'apples', 'date': '2011-07-23', 'total': 100, 'good': 80},
# ...
]
在您的模板中,按所选维度进行分组:
{% regroup harvest_data by fruits as data_by_fruits %}
{% for data in data_by_fruits %}
<h1>{{ data.grouper }}</h1> # 'apples'
{% regroup data.list by date as data_by_fruits_date %}
{% for data_1 in data_by_fruits_date %}
<h2>{{ data_1.grouper }}</h2> # '2011-07-23'
{% for datapoint in data_1.list %}
total: {{ datapoint.total }} <br/>
good: {{ datapoint.good }} <br/>
{% endfor %}
{% endfor %}
{% endfor %}