首页 > 解决方案 > 如何将大单元格分成多行并调整表格?

问题描述

我正在使用pytablewriter将数据从 postgres 写入第一个网格表。我的代码是:

from pytablewriter import RstGridTableWriter as RST
import psycopg2

if __name__ == '__main__':
    with connection.cursor(name='foo') as cursor:
        cursor.itersize = 100000
        cursor.execute(query)

        for raw_row in cursor:
            row = [
                raw_row[0],
                raw_row[1],
                raw_row[2],
                ', '.join([item for item in raw_row[3] if item])
            ]

            matrix.append(row)

    writer = RST(
        table_name='DocTable',
        headers=['col1', 'col2', 'col3', 'col4'],
        value_matrix=matrix
    )

    writer.dump('./sample.rst')

获取的每一行的最后一个值是一个字符串列表。对于每次迭代,上面的代码将字符串列表转换为逗号分隔的字符串。该字符串可能很大,并导致很大的列。

我想知道如何为每列输出一个固定宽度的表格,并将大列分成多行。例子:

细胞: "Lorem,ipsum,dolor,sit,amet,consectetur,adipiscing,elit,sed,do,eiusmod,tempor,incididunt,ut,labore,et,dolore,magna,aliqua.,Ut,enim,ad,minim,veniam,quis,nostrud,exercitation,ullamco,laboris,nisi,ut,aliquip,ex,ea,commodo,consequat"

变成:

'Lorem,'
'ipsum,'
'dolor,'
'sit,'
'amet,'
'consectetur,'
'adipiscing,'
'elit,'
'sed,'
'do,'
'eiusmod,'
'tempor,'
'incididunt,'
'ut,'
'labore,'
'et,'
'dolore,'
'magna,'
'aliqua.,'
'Ut,'
'enim,'
'ad,'
'minim,'
'veniam,'
'quis,'
'nostrud,'
'exercitation,'
'ullamco,'
'laboris,'
'nisi,'
'ut,'
'aliquip,'
'ex,'
'ea,'
'commodo,'
'consequat'

并且所有其他单元格也得到了适当的调整。

我试图把它写成',\n'.join([item for item in raw_row[3] if item])但不起作用。

标签: pythonpsycopg2restructuredtext

解决方案


nth-child您可以在不使用选择器rst-class指令的自定义 CSS 更改数据的情况下执行此操作。

非常粗略,假设第四列是麻烦。

文件.rst

.. rst-class:: my-table

[pytablewriter output]

自定义.css

table.my-table tbody tr td:nth-child(4) {
    width: 30%;
}

推荐阅读