从列表创建 HTML 表格

0 投票
3 回答
2666 浏览
提问于 2025-04-18 17:01

我有一个这样的列表:

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>

3 个回答

1

问题的一部分是,你在第一行有一个空的列,但在第二行和第三行却没有。

我把事情简化了,先删除了那个元素,然后在每一行的第三列后面加了一个空的。

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
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>&nbsp;</td>'
        print '</tr>'
    print '</table>'
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个元素,导致了问题

撰写回答