我在django模板中导致dict的dict时遇到了奇怪的问题。
data = [{'hrs': 9.0, 'ld': u'pname', 'dn': u'TS', 'ist': u'TS', 'act': u'O', 'date': datetime.date(2011, 9, 19), 'id': 1119556},
{'hrs': 9.0, 'ld': u'pname', 'dn': u'TS', 'ist': u'TS', 'act': u'Ti', 'date': datetime.date(2011, 9, 21), 'id': 1119558},
{'hrs': 2.5, 'ld': u'pname', 'dn': u'TS', 'ist': u'dmin', 'act': u'POC', 'date': datetime.date(2011, 9, 20), 'id': 1119577},
{'hrs': 0.5, 'ld': u'pname', 'dn': u'SMgr', 'ist': u'SMgr', 'act': u'PL', 'date': datetime.date(2011, 9, 20), 'id': 1119578},
{'hrs': 2.0, 'ld': u'pname', 'dn': u'SMgr', 'ist': u'TS', 'act': u'Mting', 'date': datetime.date(2011, 9, 20), 'id': 1119579},
{'hrs': 8.0, 'ld': u'sname', 'dn': u'holiday', 'ist': u'holiday', 'act': u'PL', 'date': datetime.date(2011, 9, 19), 'id': 1119455},
{'hrs': 8.0, 'ld': u'sname', 'dn': u'holiday', 'ist': u'holiday', 'act': u'PL', 'date': datetime.date(2011, 9, 21), 'id': 1119457},
{'hrs': 1.0, 'ld': u'sname', 'dn': u'TS', 'ist': u'TS', 'act': u'O', 'date': datetime.date(2011, 9, 20), 'id': 1119566},
{'hrs': 7.0, 'ld': u'sname', 'dn': u'PD', 'ist': u'PD', 'act': u'LOP', 'date': datetime.date(2011, 9, 20), 'id': 1119567}]
使用这个dict列表写下了逻辑
results = collections.defaultdict(dict)
for fetch in data:
user = fetch['ld']
get_id = fetch['id']
adata = '%s/%s/%s/%s' % (fetch['dn'], fetch['ist'], fetch['act'], fetch['hrs'])
row = results[user]
row['user'] = user
dt = str(fetch['date'])
row[dt] = adata
这给我下面的输出
结果:
{u'sname': {'2011-09-21': u'holiday/holiday/PL/8.0', '2011-09-20': u'PD/PD/LOP/7.0', 'user': u'sname', '2011-09-19': u'holiday/holiday/PL/8.0'},
u'pname': {'2011-09-21': u'TS/TS/Ti/9.0', '2011-09-20': u'SMgr/TS/Mting/2.0', 'user': u'pname', '2011-09-19': u'TS/TS/O/9.0'}}
一般情况下,我需要低于输出,但dict的dict只打印日期键值而不是同一日期的多个键值
预期输出:
{u'sname': {'2011-09-21': u'holiday/holiday/PL/8.0', '2011-09-20': u'TS/TS/O/1.0', '2011-09-20': u'PD/PD/LOP/7.0', 'user': u'sname', '2011-09-19': u'holiday/holiday/PL/8.0'},
u'pname': {'2011-09-21': u'TS/TS/Trickle/9.0', '2011-09-20': u'TS/dmin/POC/2.5', '2011-09-20': u'SMgr/Smgr/PL/0.5', '2011-09-20': u'SMgr/TS/Mting/2.0' 'user': u'pname', '2011-09-19': u'TechSupport/TechSupport/O/9.0'}}
我正在使用下面的模板标签来散列表格
模板:
@register.filter
def hash(object, attr):
gen_context = { 'object' : object }
try:
value = template.Variable('object.%s' % attr).resolve(gen_context)
except template.VariableDoesNotExist:
value = ' '
return value
HTML:
<table>
<thead>
<th>S.No</th>
<th>Name</th>
{% for dates in week_dates %}
<th>{{dates}}</th>
{% endfor %}
</thead>
<tr>
{% for fetch in data.items %}
<tr>
<td>{{ forloop.counter }}</td>
<td>{{ fetch.0 }}</td>
{% for dates in week_dates %}
<td>{{ fetch.1|hash:dates }}</td>
{% endfor %}
</tr>
{% endfor %}
</table>
任何帮助都非常感激。
如果您需要更多信息,请与我们联系。
答案 0 :(得分:2)
正如教程 AT LEAST ONCE 中所解释的,字典键是唯一。如果你想为一个键设置多个值,那么你必须用序列伪造它。
{'foo': ['bar', 42]}
答案 1 :(得分:0)
字典中的同一个键不能有多个值。键必须是不同的。因此,如果您尝试保存日期 - 值对并且日期已经是dictionairy中的键,则其值将被覆盖。因此,您必须使用一个非常独特的密钥来改变内部dicts的结构。 ids怎么样?据我所知,你在get_id中读取它们但不使用它们。他们将非常适合这份工作。然后,您可以使用元组将所有内容保存在类似于{id: (date, adata)}
的结构中。