我有一本字典:
field =
{
u'Birthday:': [datetime.date(2012, 4, 6), datetime.date(2012, 4, 27)],
u'Education': [u'A1', u'A2'],
u'Job:': [u'job1', u'job2'],
u'Child Sex:': [u'M', u'F']
}
我的模板代码是:
<table width="100%" border="0">
<tr>
{% for k, v in field.items %}
<th>{{ k }}</th>
{% endfor %}
</tr>
<tr>
{% for k,v in field.items %}
<td>
<table width="100%" border="0">
{% for a in v %}
<tr class="{% cycle 'odd' 'even' %}"><td>{{ a }}</td></tr>
{% endfor %}
</table>
</td>
{% endfor %}
</tr>
</table>
我想将字典键显示为表格标题,并将值显示为行:
Birthday Education Job Child Sex
datetime.date(2012, 4, 6) A1 job1 M
datetime.date(2012, 4, 27) A2 job2 F
但我必须插入第二张表。是否有任何方法可以将字典键作为表格标题和esach值作为行?
提前致谢
答案 0 :(得分:6)
如果您将数据作为字典中的表格提供,则可以使模板代码更容易阅读。它看起来更像是这样:
field = {
'headers': [u'Birthday:', u'Education', u'Job', u'Child Sex'],
'rows': [[datetime.date(2012, 4, 6), u'A1', u'job1', u'M']
,[datetime.date(2012, 4, 27), u'A2', u'job2', u'F']]
}
您现在可以按如下方式迭代标题:
<tr>
{% for header in field.headers %}
<th>{{ header }}</th>
{% endfor %}
</tr>
每行都可以使用以下方式显示:
<tr>
{% for value in field.rows %}
<td>{{ value }}</td>
{% endfor %}
</tr>
现在,您可以使用'headers'
获取field.keys()
值:
[u'Birthday:', u'Education', u'Job:', u'Child Sex:']
您可以使用以下循环获取'values'
(其中2
是行数):
rows = []
for i in xrange(2):
row = []
for k in field.keys():
row.append(field[k][i])
rows.append(row)
或者作为一个单行:
rows = [[field[k][i] for k in field.keys()] for i in xrange(2)]
答案 1 :(得分:0)
Simeon的回答对我有用,但由于嵌套列表,我必须在模板中做一些不同的事情以使行和数据看起来正确:
{% for row in field.rows %}
<tr>
{% for value in row %}
<td>{{value}}</td>
{% endfor %}
</tr>
{% endfor %}