我正在尝试从存储在表中的数据创建HTML表。我从表中读取数据并将其转换为列表的字典,例如:
x = {'date':[u'2012-06-28', u'2012-06-29', u'2012-06-30'], 'users': [405, 368, 119]}
我的目标是为任意列表长度创建一个具有以下结构的HTML表:
<table>
<thead>
<th>Date</th>
<th>Users</th>
</thead>
<tbody>
<tr>
<td>2012-06-28</td>
<td>405</td>
</tr>
<tr>
<td>2012-06-29</td>
<td>368</td>
</tr>
<tr>
<td>2012-06-30</td>
<td>119</td>
</tr>
</tbody>
</table>
我在Flask模板中试过这两种不正确的方法:
<tbody>
{% for line in x %}
<tr>
<td>{{ x.date|tojson|safe }}</td>
<td>{{ x.users }}</td>
</tr>
{% endfor %}
</tbody>
将整个列表打印到每列中。
和
{% for date in x.date %}
<tr><td>{{ date|tojson|safe }}</td></tr>
{% endfor %}
{% for users in x.users %}
<tr><td>{{ users }}</td></tr>
{% endfor %}
只需将所有内容打印到第一列。
这些实验和许多其他死胡同使我相信,根据我目前的数据结构,没有简单的方法来构建表格。
鉴于此,我有两个问题:
1)如何使用我当前的数据结构构建表格?
2)为这个用例构建数据的标准或理想方法是什么?
提前致谢。
答案 0 :(得分:24)
如您所说,您可以更改数据结构,也可以更改模板代码。这是保持当前结构的一种方法:
{% for row_index in range(x['date']|count) %}
<tr>
<td>{{ x['date'][row_index]|tojson|safe }}</td>
<td>{{ x['users'][row_index] }}</td>
</tr>
{% endfor %}
或者您可以在python中重构数据:
x = zip(x['date'], x['users'])
然后使用此模板:
{% for row in x %}
<tr>
<td>{{ row[0]|tojson|safe }}</td>
<td>{{ row[1] }}</td>
</tr>
{% endfor %}
您还可以构建数据,以便模板不依赖于单元格的顺序:
from itertools import izip
x = [dict(date=d, user=u) for d, u in izip(x['date'], x['users'])]
然后您可以像这样访问您的数据:
{% for row in x %}
<tr>
<td>{{ row['date']|tojson|safe }}</td>
<td>{{ row['user'] }}</td>
</tr>
{% endfor %}
答案 1 :(得分:3)
您可以使用Flask-Table或更复杂的内容,甚至可以利用Flask-Admin。
答案 2 :(得分:1)
是的,你真的想用一个字典列表而不是列表字典,这可以用Jinja2更好地用