我使用yattag创建HTML,并且在我的代码中,我想遍历数据库记录,并动态创建HTML表。
例如,如果中的div数为5:
with tag('table', klass='all-pr'):
with tag('tr'):
with tag('td'):
for zone in all_zones:
clear += 1
with tag('div', klass='pr' + ' ' + risk_alert):
text(zone['name'])
with tag('div', klass='link-pr'):
text('-')
if (clear % 5 == 0):
# create a new <tr>
更新: 好的,我期望的HTML是:
<table class="all-pr" >
<tr>
<td>
<div class="pr risk-alert-high">114</div>
<div class="link-pr">-</div>
<div class="pr risk-alert-high">115</div>
<div class="link-pr">-</div>
<div class="pr risk-alert-high">116</div>
<div class="link-pr">-</div>
<div class="pr risk-alert-high">117</div>
<div class="link-pr">-</div>
<div class="pr risk-alert-high">118</div>
<div class="link-pr">-</div>
</td>
</tr>
<!-- BREAK HERE -->
<tr>
<td>
<div class="pr risk-alert-high">119</div>
<div class="link-pr">-</div>
<div class="pr risk-alert-high">120</div>
<div class="link-pr">-</div>
<div class="pr risk-alert-high">121</div>
<div class="link-pr">-</div>
<div class="pr risk-alert-high">122</div>
<div class="link-pr">-</div>
<div class="pr risk-alert-high">123</div>
<div class="link-pr">-</div>
</td>
</tr>
...
...
</table>
(CSS的一部分):
.link-pk, .pr {
text-align: center;
float: left;
margin-top: 5px;
padding: 5px;
width : 25px
}
然后,我用PDFKIT lib转换PDF中的HTML。
但是我不知道如何关闭标签并(重新)创建新标签,然后继续循环... 有什么想法吗?
谢谢, F。
答案 0 :(得分:0)
所以问题不仅仅在于亚塔格,对不对?您的问题是将元素按5组(或任何固定数量)进行处理。
为此,我将使用itertools模块中的islice
方法。
您有一个示例,说明如何使用此函数创建一个take
函数,该函数采用可迭代的前n
个元素:
https://docs.python.org/3/library/itertools.html#itertools-recipes
使用此take
函数,您可以消耗n
组元素中的一个可迭代对象。这是您特定问题的解决方案:
from itertools import islice
from yattag import Doc, indent
def take(n, iterable):
"Return first n items of the iterable as a list"
return list(islice(iterable, n))
def zones_to_html(zones):
zones_iterator = iter(zones) # in case zones is not already an iterator
doc, tag, text, line = Doc().ttl()
with tag('table', klass="all-pr"):
while True:
first5 = take(5, zones_iterator)
if len(first5) == 0:
break
else:
with tag('tr'):
with tag('td'):
for zone in first5:
line('div', zone['name'], klass = 'pr ' + zone['risk_alert'])
line('div', '-', klass='link-pr')
return doc.getvalue()
# Example of use:
if __name__ == '__main__':
all_zones = ({'name': i, 'risk_alert': 'high'} for i in range(114, 129))
print(indent(zones_to_html(all_zones)))
我使用了Yattag的line
方法,这里介绍了一种快捷方式:http://www.yattag.org/#shortcut-for-nodes-that-contain-only-text