Szöveg formázása Pythonban

Szöveg formázása Pythonban

Aspose.Slides FOSS for Python finomhangolt szövegformázást biztosít a PortionFormat osztályon keresztül. A Portion a legkisebb önálló szövegegység; egy bekezdésen belüli egyetlen formázási futamra térképeződik. Ez az útmutató bemutatja, hogyan lehet félkövér, dőlt, betűméret és szín formázást alkalmazni a prezentáció szövegére.

Lépésről‑lépésre útmutató

1. lépés: A csomag telepítése

pip install aspose-slides-foss

2. lépés: Alakzat hozzáadása szövegkerettel

A szöveg formázása előtt egy alakzatnak tartalmaznia kell egy TextFrame. Használja a shape.add_text_frame()-t egy létrehozásához.

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)

3. lépés: A TextFrame elérése

shape.add_text_frame() visszaadja a TextFrame objektumot. Később is lekérhető a shape.text_frame segítségével.

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

A TextFrame egy listát tartalmaz Paragraph objektumokból (tf.paragraphs). Minden Paragraph Portion objektumot tartalmaz (paragraph.portions).


4. lépés: Félkövér és dőlt formázás alkalmazása

Használja portion_format.font_bold és portion_format.font_italic. Ezek a tulajdonságok elfogadják a NullableBool.TRUE, NullableBool.FALSE vagy NullableBool.NOT_DEFINED értékeket (öröklődés a masterből).

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)

5. lépés: Betűméret és szín beállítása

Állítsa be portion_format.font_height a mérethez (pontban), és használja fill_format‑t a színhez.

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) minden csatornára 0–255 értékeket fogad el.


6. lépés: Több rész egy bekezdésben

Egy bekezdés több, különböző formázású részt is tartalmazhat. Adj hozzá egy új Portion a bekezdés portions gyűjteményéhez:

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)

Gyakori problémák és megoldások

A szöveg fekete marad a szín beállítása után

Győződjön meg róla, hogy a fill_format.fill_type = FillType.SOLID be van állítva, mielőtt a színt hozzárendeli. A kitöltéstípus beállítása nélkül a színváltozás hatástalan lehet.

NullableBool.TRUE vs True

portion_format.font_bold a NullableBool.TRUE-t várja, nem a Python True-t. A Python True hozzárendelése kiválthat egy TypeError-t, vagy csendben semmit sem tehet a kötéstől függően.

A betűtípus nem jelenik meg a mentett fájlban

A latin_font tulajdonság beállítja a latin betűcsaládot. Ha nincs beállítva, a prezentáció témájának betűtípusa lesz használva. Az egyéni betűtípusokat be kell ágyazni, vagy elérhetőknek kell lenniük a megtekintő gépen.


Gyakran Ismételt Kérdések

Hogyan változtathatom meg a betűcsaládot?

Állítsa be portion_format.latin_font:

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

FontData elfogadja a betűcsalád nevét karakterláncként.

Hogyan állíthatom be a bekezdés igazítását?

Használja paragraph_format.alignment:

from aspose.slides_foss import TextAlignment

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

Támogatott értékek: LEFT, CENTER, RIGHT, JUSTIFY.

Hogyan állíthatom be a sortávolságot?

Használja paragraph_format.space_before (pontok a bekezdés előtt) vagy paragraph_format.space_after (pontok a bekezdés után):

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

Lásd még

 Magyar