Python에서 테이블 작업하기
Aspose.Slides FOSS for Python은 구성 가능한 열 너비와 행 높이를 가진 슬라이드에 표를 만드는 것을 지원합니다. 이 가이드는 표를 추가하고 데이터를 채우며 셀에 기본 텍스트 서식을 적용하는 방법을 보여줍니다.
단계별 가이드
1단계: 패키지 설치
pip install aspose-slides-foss2단계: 프레젠테이션 만들기 또는 열기
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]
행 및 열 인덱스는 0부터 시작합니다. row_heights을 3개의 요소로 정의한 경우, 유효한 행 인덱스는 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) <= 720와 y + 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 참조를 참조하십시오.