Ako formátovať text v Pythone

Aspose.Slides FOSS for Python poskytuje detailné formátovanie textu prostredníctvom triedy PortionFormat. Portion je najmenšia nezávislá jednotka textu; mapuje sa na jeden formátovací beh v odstavci. Tento sprievodca ukazuje, ako použiť formátovanie tučného, kurzívneho, veľkosti písma a farby na text v prezentácii.

Návod krok za krokom

Krok 1: Nainštalovať balík

pip install aspose-slides-foss

Krok 2: Pridať tvar s textovým rámcom

Pred formátovaním textu musí tvar obsahovať TextFrame. Použite shape.add_text_frame() na jeho vytvorenie.

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)

Krok 3: Prístup k TextFrame

shape.add_text_frame() vracia objekt TextFrame. Môžete ho tiež neskôr získať prostredníctvom shape.text_frame.

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

TextFrame obsahuje zoznam objektov Paragraph (tf.paragraphs). Každý Paragraph obsahuje objekty Portion (paragraph.portions).


Krok 4: Použiť tučné a kurzívne formátovanie

Použite portion_format.font_bold a portion_format.font_italic. Tieto vlastnosti akceptujú NullableBool.TRUE, NullableBool.FALSE alebo NullableBool.NOT_DEFINED (zdediť z mastera).

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)

Krok 5: Nastavte veľkosť písma a farbu

Nastavte portion_format.font_height pre veľkosť (v bodoch) a použite fill_format pre farbu.

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) akceptuje hodnoty 0–255 pre každý kanál.


Krok 6: Viacero častí v jednom odseku

Jeden odsek môže obsahovať viacero častí s rôznym formátovaním. Pridajte nový Portion do kolekcie portions odseku:

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)

Bežné problémy a riešenia

Text sa zobrazuje čierne aj po nastavení farby

Uistite sa, že je fill_format.fill_type = FillType.SOLID nastavený pred priradením farby. Bez nastavenia typu výplne môže zmena farby nemáť žiadny účinok.

NullableBool.TRUE vs True

portion_format.font_bold očakáva NullableBool.TRUE, nie Python True. Priradenie Python True môže vyvolať TypeError alebo ticho nič neurobiť v závislosti od väzby.

Písmo sa v uloženom súbore nezobrazuje

Vlastnosť latin_font nastavuje rodinu latinských písiem. Ak nie je nastavená, použije sa písmo témy prezentácie. Vlastné písma musia byť vložené alebo dostupné na zobrazovacom zariadení.


Často kladené otázky

Ako zmením rodinu písma?

Nastaviť portion_format.latin_font:

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

FontData akceptuje názov rodiny písma ako reťazec.

Ako nastaviť zarovnanie odseku?

Použiť paragraph_format.alignment:

from aspose.slides_foss import TextAlignment

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

Podporované hodnoty: LEFT, CENTER, RIGHT, JUSTIFY.

Ako nastaviť riadkový rozostup?

Použite paragraph_format.space_before (bodky pred odstavcom) alebo paragraph_format.space_after (bodky po odstavci):

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

Pozri tiež

 Slovenčina