django中dict问题的词典

时间:2011-09-20 23:58:06

标签: python django django-templates

我在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>

任何帮助都非常感激。

如果您需要更多信息,请与我们联系。

2 个答案:

答案 0 :(得分:2)

正如教程 AT LEAST ONCE 中所解释的,字典键是唯一。如果你想为一个键设置多个值,那么你必须用序列伪造它。

{'foo': ['bar', 42]}

答案 1 :(得分:0)

字典中的同一个键不能有多个值。键必须是不同的。因此,如果您尝试保存日期 - 值对并且日期已经是dictionairy中的键,则其值将被覆盖。因此,您必须使用一个非常独特的密钥来改变内部dicts的结构。 ids怎么样?据我所知,你在get_id中读取它们但不使用它们。他们将非常适合这份工作。然后,您可以使用元组将所有内容保存在类似于{id: (date, adata)}的结构中。