html-table

邮件报表 之类的开发任务中,需要生成 HTML 表格。

使用 Python 生成 HTML 表格基本没啥难度, for 循环遍历一遍数据并输出标签即可。如果需要实现合并单元格,或者按需调整表格样式,就比较麻烦了。

这时,可以试试本文的主角—— html-table 包,借助它可生成各种样式的 HTML 表格。接下来,以一个简单的例子演示 html-table 的常用用法:

../_images/997ad67a7f305a39e5a77e3bf86c7798.png

开始之前,须通过 pip 安装 html-table 包:

  1. $ python -m pip install html-table

安装完毕后,即可导入 HTMLTable 类:

  1. from HTMLTable import (
  2. HTMLTable,
  3. )

创建一个新表格,标题为 果园收成表

  1. # 标题
  2. table = HTMLTable(caption='果园收成表')

附上表头:

  1. # 表头行
  2. table.append_header_rows((
  3. ('名称', '产量 (吨)', '环比', ''),
  4. ('', '', '增长量 (吨)', '增长率 (%)'),
  5. ))

注意到,表头分为两行,有些单元格需要合并,被合并的单元格需要留空占位。

合并单元格设置:

  1. # 合并单元格
  2. table[0][0].attr.rowspan = 2
  3. table[0][1].attr.rowspan = 2
  4. table[0][2].attr.colspan = 2

table[0] 取出第一行,即第一个 <tr> 标签;table[0][0] 取出第一个单元格,对应 名称table[0][0].attr 则是其标签 <th> 的属性。该单元格合并下方一个单元格,需要将标签属性 rowspan 设置为 2

接着,加入数据,方法与表头类似,总共有 3 行:

  1. # 数据行
  2. table.append_data_rows((
  3. ('荔枝', 11, 1, 10),
  4. ('芒果', 9, -1, -10),
  5. ('香蕉', 6, 1, 20),
  6. ))

至此,数据准备完毕,可以着手调整样式。先设置表格标题样式:

  1. # 标题样式
  2. table.caption.set_style({
  3. 'font-size': '15px',
  4. })

设置 <table> 标签的样式:

  1. # 表格样式,即<table>标签样式
  2. table.set_style({
  3. 'border-collapse': 'collapse',
  4.  
  5. 'word-break': 'keep-all',
  6. 'white-space': 'nowrap',
  7. 'font-size': '14px',
  8. })

以上 CSS 样式设置在 <table> 标签上,作用于整个表格,影响表格边框、字体大小等。注意到,下面会覆盖部分单元格(如表头单元格)的字体大小。

接着,设置每个单元格的样式,主要是规定边框样式:

  1. # 统一设置所有单元格样式,<td>或<th>
  2. table.set_cell_style({
  3. 'border-color': '#000',
  4. 'border-width': '1px',
  5. 'border-style': 'solid',
  6.  
  7. 'padding': '5px',
  8. })

接着,设置表头单元格样式,规定颜色、字体大小、以及填充大小:

  1. # 表头样式
  2. table.set_header_row_style({
  3. 'color': '#fff',
  4. 'background-color': '#48a6fb',
  5. 'font-size': '18px',
  6. })
  7. # 覆盖表头单元格字体样式
  8. table.set_header_cell_style({
  9. 'padding': '15px',
  10. })

set_header_row_style 将样式设置到表头两个 <tr> 标签上;set_header_cell_style 则将样式设置到每个 <th> 标签上。应该尽量将颜色等样式设置到 <tr> 标签上,而不是 <th> 标签上,以精简生成的 HTML

将次级表头字体大小调小,不在赘述:

  1. # 调小次表头字体大小
  2. table[1].set_cell_style({
  3. 'padding': '8px',
  4. 'font-size': '15px',
  5. })

遍历每个数据行,如果第 2 个单元格值小于 0 ,设置样式标红背景颜色:

  1. # 遍历数据行,如果增长量为负,标红背景颜色
  2. for row in table.iter_data_rows():
  3. if row[2].value < 0:
  4. row.set_style({
  5. 'background-color': '#ffdddd',
  6. })

最后,生成 HTML 文本:

  1. html = table.to_html()
  2. print(html)

下一步

订阅更新,获取更多学习资料,请关注我们的 微信公众号

../_images/wechat-mp-qrcode.png小菜学编程

微信打赏