Como formatar texto em Python

Como formatar texto em Python

Aspose.Slides FOSS for Python provides fine-grained text formatting through the PortionFormat classe. A Portion é a menor unidade independente de texto; corresponde a uma única execução de formatação dentro de um parágrafo. Este guia mostra como aplicar formatação em negrito, itálico, tamanho de fonte e cor ao texto em uma apresentação.

Guia passo a passo

Etapa 1: Instale o pacote

pip install aspose-slides-foss

Etapa 2: Adicionar uma Forma com um Quadro de Texto

Antes de formatar o texto, um shape deve conter um TextFrame. Use shape.add_text_frame() para criar um.

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

with slides.Presentation() as prs:
    slide = prs.slides[0]
    shape = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 50, 50, 500, 150)
    tf = shape.add_text_frame("Default text: will be formatted")
    prs.save("output.pptx", SaveFormat.PPTX)

Etapa 3: Acessar o TextFrame

shape.add_text_frame() retorna o TextFrame objeto. Você também pode recuperá-lo mais tarde via shape.text_frame.

tf = shape.text_frame          # if the frame already exists
tf = shape.add_text_frame("") # creates a new frame

Um TextFrame contém uma lista de Paragraph objetos (tf.paragraphs). Cada Paragraph contém Portion objetos (paragraph.portions).


Etapa 4: Aplicar Formatação em Negrito e Itálico

Use portion_format.font_bold e portion_format.font_italic. Estas propriedades aceitam NullableBool.TRUE, NullableBool.FALSE, ou NullableBool.NOT_DEFINED (herdar do mestre).

import aspose.slides_foss as slides
from aspose.slides_foss import ShapeType, NullableBool
from aspose.slides_foss.export import SaveFormat

with slides.Presentation() as prs:
    slide = prs.slides[0]
    shape = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 50, 50, 500, 150)
    tf = shape.add_text_frame("Bold and italic text")

    fmt = tf.paragraphs[0].portions[0].portion_format
    fmt.font_bold = NullableBool.TRUE
    fmt.font_italic = NullableBool.TRUE

    prs.save("bold-italic.pptx", SaveFormat.PPTX)

Etapa 5: Definir Tamanho da Fonte e Cor

Defina portion_format.font_height para tamanho (em pontos) e use fill_format para cor.

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

with slides.Presentation() as prs:
    slide = prs.slides[0]
    shape = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 50, 50, 500, 150)
    tf = shape.add_text_frame("Large corporate-blue heading")

    fmt = tf.paragraphs[0].portions[0].portion_format
    fmt.font_height = 32                          # 32pt font
    fmt.font_bold = NullableBool.TRUE
    fmt.fill_format.fill_type = FillType.SOLID
    fmt.fill_format.solid_fill_color.color = Color.from_argb(255, 0, 70, 127)

    prs.save("colored-text.pptx", SaveFormat.PPTX)

Color.from_argb(alpha, red, green, blue) aceita valores 0–255 para cada canal.


Etapa 6: Múltiplas Porções em um Único Parágrafo

Um único parágrafo pode conter várias partes com formatação diferente. Adicione um novo Portion a um parágrafo portions coleção:

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

with slides.Presentation() as prs:
    slide = prs.slides[0]
    shape = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 50, 50, 600, 100)
    tf = shape.add_text_frame("")  # start with empty frame

    paragraph = tf.paragraphs[0]

    # First portion: normal text
    portion1 = paragraph.portions[0]
    portion1.text = "Normal text followed by "
    portion1.portion_format.font_height = 20

    # Second portion: bold red text
    portion2 = slides.Portion()
    portion2.text = "bold red text"
    portion2.portion_format.font_height = 20
    portion2.portion_format.font_bold = NullableBool.TRUE
    portion2.portion_format.fill_format.fill_type = FillType.SOLID
    portion2.portion_format.fill_format.solid_fill_color.color = Color.from_argb(255, 200, 0, 0)
    paragraph.portions.add(portion2)

    prs.save("mixed-format.pptx", SaveFormat.PPTX)

Problemas comuns e correções

O texto aparece preto mesmo após definir a cor

Certifique-se fill_format.fill_type = FillType.SOLID é definido antes de atribuir a cor. Sem definir o tipo de preenchimento, a alteração de cor pode não ter efeito.

NullableBool.TRUE vs True

portion_format.font_bold espera NullableBool.TRUE, não o Python True. Atribuindo Python True pode gerar um TypeError ou ficar silencioso sem fazer nada, dependendo da vinculação.

A fonte não aparece no arquivo salvo

O latin_font A propriedade define a família de fontes Latin. Se não for definida, a fonte do tema da apresentação será usada. Fontes personalizadas devem estar incorporadas ou disponíveis na máquina de visualização.


Perguntas Frequentes

Como altero a família de fontes?

Definir portion_format.latin_font:

fmt.latin_font = slides.FontData("Arial")

FontData aceita o nome da família de fontes como uma string.

Como defino o alinhamento do parágrafo?

Usar paragraph_format.alignment:

from aspose.slides_foss import TextAlignment

tf.paragraphs[0].paragraph_format.alignment = TextAlignment.CENTER

Valores suportados: LEFT, CENTER, RIGHT, JUSTIFY.

Como defino o espaçamento entre linhas?

Usar paragraph_format.space_before (pontos antes do parágrafo) ou paragraph_format.space_after (pontos depois do parágrafo):

tf.paragraphs[0].paragraph_format.space_before = 12   # 12pt before
tf.paragraphs[0].paragraph_format.space_after = 6     # 6pt after

Veja também

 Português