所以我有一个这样的列表:
l = ['ID', 'Format', 'Width', 'Height', '\xc2\xa0', 'ID', 'Format', 'Width', 'Height', '0', 'original', 'original', 'original', '88', 'JPG', '247', '131', '1', 'JPG', '172', '128', '90', 'JPG', '240', '320']
我正在尝试从此列表中创建一个HTML表格,使其看起来像这样:
正如您所看到的,每个第4个元素都是空白的(从0开始作为第一个元素的索引),并且在每个第8个元素之后创建一个新行。我试过这个:
def reformat_html_id_table(line):
htmlTable = '<table>\n'
for i in range(0, len(line)):
if (i < 0 and i % 3 == 0):
htmlTable = htmlTable + '\t<td> </td>\n'
elif i % 9 == 0:
if i == 0:
htmlTable = htmlTable + '<tr>\n'
else:
htmlTable = htmlTable + '</tr>\n<tr>\n'
htmlTable = htmlTable + '\t<td>{0}</td>\n'.format(line[i])
else:
htmlTable = htmlTable + '\t<td>{0}</td>\n'.format(line[i])
htmlTable = htmlTable + '</tr>\n</table>'
print htmlTable
这会产生:
<table>
<tr>
<td>ID</td>
<td>Format</td>
<td>Width</td>
<td>Height</td>
<td> </td>
<td>ID</td>
<td>Format</td>
<td>Width</td>
<td>Height</td>
</tr>
<tr>
<td>0</td>
<td>original</td>
<td>original</td>
<td>original</td>
<td>88</td>
<td>JPG</td>
<td>247</td>
<td>131</td>
<td>1</td>
</tr>
<tr>
<td>JPG</td>
<td>172</td>
<td>128</td>
<td>90</td>
<td>JPG</td>
<td>240</td>
<td>320</td>
</tr>
</table>
哪种排序正确,第一行是正确的,但之后它没有和空白数据再次,我很困惑为什么。谁能告诉我我做错了什么?预期的输出是:
<table>
<tr>
<td>ID</td>
<td>Format</td>
<td>Width</td>
<td>Height</td>
<td> </td>
<td>ID</td>
<td>Format</td>
<td>Width</td>
<td>Height</td>
</tr>
<tr>
<td>0</td>
<td>original</td>
<td>original</td>
<td>original</td>
<td> </td>
<td>88</td>
<td>JPG</td>
<td>247</td>
<td>131</td>
</tr>
<tr>
<td>1</td>
<td>JPG</td>
<td>172</td>
<td>128</td>
<td> </td>
<td>90</td>
<td>JPG</td>
<td>240</td>
<td>320</td>
</tr>
</table>
答案 0 :(得分:1)
使用此代码从列表中创建HTML表格:
def print_table(data, row_length):
print '<table>'
counter = 0
for element in data:
if counter % row_length == 0:
print '<tr>'
print '<td>%s</td>' % element
counter += 1
if counter % row_length == 0:
print '</tr>'
if counter % row_length != 0:
for i in range(0, row_length - counter % row_length):
print '<td> </td>'
print '</tr>'
print '</table>'
答案 1 :(得分:1)
问题的一部分是你在第一个条目中有空列,但在第二个和第三个条目中没有。
我通过首先删除该元素然后在每行的第三列之后添加空白td来保持简单:
def reformat_html_id_table(line):
del(line[4]) # remove '\xc2\xa0'
htmlTable = '<table>\n'
for i in range(0, len(line)):
posInRow = i % 8
# begin row
if (posInRow == 0):
htmlTable += '<tr>'
htmlTable += '\t<td>{0}</td>\n'.format(line[i])
# add empty row
if (posInRow == 3):
htmlTable += '\t<td> </td>\n'
# end row
if (posInRow == 7):
htmlTable += '</tr>'
htmlTable += '</table>'
print htmlTable
答案 2 :(得分:1)
稍微修改一下你自己的代码,这是非常好的
def reformat_html_id_table(line):
htmlTable = '<table>\n'
mod = 9
for i in range(0, len(line)):
if (i > mod and i%mod == 5):
htmlTable = htmlTable + '\t\t<td> </td>\n'
if (i-9) % mod == 0:
if i == 0:
htmlTable = htmlTable + '\t<tr>\n'
else:
htmlTable = htmlTable + '\t</tr>\n\t<tr>\n'
htmlTable = htmlTable + '\t\t<td>{0}</td>\n'.format(line[i])
else:
htmlTable = htmlTable + '\t\t<td>{0}</td>\n'.format(line[i])
if i==9:
mod=8
htmlTable = htmlTable + '\t</tr>\n</table>'
print htmlTable
第9行的第一行和第8行的其余部分似乎是一个问题