如何在 Python 中使用表格

如何在 Python 中使用表格

Aspose.Slides FOSS for Python 支持在幻灯片上创建具有可配置列宽和行高的表格。本指南展示了如何添加表格、填充数据以及对单元格应用基本文本格式。

分步指南

步骤 1:安装软件包

pip install aspose-slides-foss

步骤 2:创建或打开演示文稿

import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat

with slides.Presentation() as prs:
    slide = prs.slides[0]
    # ... add table ...
    prs.save("table.pptx", SaveFormat.PPTX)

步骤 3:定义列宽和行高

表格需要以点为单位明确指定列宽和行高(1 点 = 1/72 英寸)。标准幻灯片的宽度为 720 点,高度为 540 点。

col_widths = [200.0, 150.0, 150.0]   # 3 columns: 200pt + 150pt + 150pt
row_heights = [45.0, 40.0, 40.0]     # 3 rows: 45pt header + 40pt data rows

步骤 4:添加表格

slide.shapes.add_table(x, y, col_widths, row_heights) 在位置 (x, y) 创建表格:

import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat

with slides.Presentation() as prs:
    slide = prs.slides[0]

    col_widths = [200.0, 150.0, 150.0]
    row_heights = [45.0, 40.0, 40.0]
    table = slide.shapes.add_table(50, 100, col_widths, row_heights)

    prs.save("table.pptx", SaveFormat.PPTX)

步骤 5:设置单元格文本

通过 table.rows[row_index][col_index] 访问单元格,并通过 .text_frame.text 分配文本:

import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat

with slides.Presentation() as prs:
    slide = prs.slides[0]

    col_widths = [200.0, 150.0, 150.0]
    row_heights = [45.0, 40.0, 40.0]
    table = slide.shapes.add_table(50, 100, col_widths, row_heights)

    # Header row (row 0)
    headers = ["Product", "Units Sold", "Revenue"]
    for col, header in enumerate(headers):
        table.rows[0][col].text_frame.text = header

    # Data rows
    data = [
        ["Widget A", "1,200", "$24,000"],
        ["Widget B", "850", "$17,000"],
    ]
    for row_idx, row_data in enumerate(data):
        for col, cell_text in enumerate(row_data):
            table.rows[row_idx + 1][col].text_frame.text = cell_text

    prs.save("sales-table.pptx", SaveFormat.PPTX)

步骤 6:格式化标题单元格文本

使用 PortionFormat 对标题单元格应用粗体格式:

from aspose.slides_foss import NullableBool, FillType
from aspose.slides_foss.drawing import Color

for col in range(len(headers)):
    cell = table.rows[0][col]
    portions = cell.text_frame.paragraphs[0].portions
    if portions:
        fmt = portions[0].portion_format
        fmt.font_bold = NullableBool.TRUE
        fmt.fill_format.fill_type = FillType.SOLID
        fmt.fill_format.solid_fill_color.color = Color.from_argb(255, 255, 255, 255)

完整工作示例

import aspose.slides_foss as slides
from aspose.slides_foss import NullableBool, FillType
from aspose.slides_foss.drawing import Color
from aspose.slides_foss.export import SaveFormat

data_rows = [
    ["North", "$1.2M", "+8%"],
    ["South", "$0.9M", "+4%"],
    ["East",  "$1.5M", "+12%"],
    ["West",  "$0.7M", "+2%"],
]
headers = ["Region", "Revenue", "Growth"]

with slides.Presentation() as prs:
    slide = prs.slides[0]

    col_widths = [180.0, 140.0, 120.0]
    row_heights = [45.0] + [38.0] * len(data_rows)

    table = slide.shapes.add_table(60, 80, col_widths, row_heights)

    # Header row
    for col, text in enumerate(headers):
        cell = table.rows[0][col]
        cell.text_frame.text = text
        if cell.text_frame.paragraphs and cell.text_frame.paragraphs[0].portions:
            fmt = cell.text_frame.paragraphs[0].portions[0].portion_format
            fmt.font_bold = NullableBool.TRUE

    # Data rows
    for row_idx, row_data in enumerate(data_rows):
        for col, text in enumerate(row_data):
            table.rows[row_idx + 1][col].text_frame.text = text

    prs.save("regional-revenue.pptx", SaveFormat.PPTX)

print("Saved regional-revenue.pptx")

常见问题及解决方案

IndexError 在访问 table.rows[row][col]

行和列索引是从零开始的。如果您使用 3 个元素定义了 row_heights,有效的行索引为 0、1、2。

单元格文本未出现在保存的文件中

始终通过 .text_frame.text 进行赋值,而不要直接在单元格对象上通过 .text 进行赋值:

# Correct
table.rows[0][0].text_frame.text = "Header"

# Wrong: AttributeError or silent failure
table.rows[0][0].text = "Header"

表格位置偏离幻灯片

检查标准幻灯片的 x + sum(col_widths) <= 720y + sum(row_heights) <= 540


常见问题

我可以合并表格单元格吗?

此版本不支持单元格合并。

我可以为整个表格应用背景颜色吗?

对每个单元格应用填充格式:

for row_idx in range(len(table.rows)):
    for col_idx in range(len(table.rows[row_idx])):
        cell = table.rows[row_idx][col_idx]
        cell.fill_format.fill_type = FillType.SOLID
        cell.fill_format.solid_fill_color.color = Color.from_argb(255, 240, 248, 255)

我可以设置单元格边框样式吗?

可以通过 table.rows[row][col].border_* 属性访问单元格边框属性。请参阅 API 参考以获取完整的边框格式属性列表。


另请参阅

 中文