Kaip formatuoti tekstą su Python

Kaip formatuoti tekstą su Python

Aspose.Slides FOSS for Python provides fine-grained text formatting through the PortionFormat klasė. A Portion yra mažiausia nepriklausoma teksto vienetas; jis atitinka vieną formatavimo seką pastraipoje. Ši vadovas rodo, kaip pritaikyti pusjuodį, kursyvą, šrifto dydį ir spalvos formatavimą tekstui pristatyme.

Žingsnis po žingsnio vadovas

Žingsnis 1: Įdiekite paketą

pip install aspose-slides-foss

Žingsnis 2: Pridėkite formą su teksto rėmeliu

Prieš formatuojant tekstą, forma turi turėti TextFrame. Naudokite shape.add_text_frame() sukurti vieną.

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)

Žingsnis 3: Pasiekite TextFrame

shape.add_text_frame() grąžina TextFrame objektą. Taip pat galite jį vėliau gauti per shape.text_frame.

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

A TextFrame turi sąrašą Paragraph objektų (tf.paragraphs). Kiekvienas Paragraph turi Portion objektų (paragraph.portions).


Žingsnis 4: Taikykite pusjuodį ir kursyvo formatavimą

Naudokite portion_format.font_bold ir portion_format.font_italic. Šios savybės priima NullableBool.TRUE, NullableBool.FALSE, arba NullableBool.NOT_DEFINED (paveldėti iš master).

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)

Žingsnis 5: Nustatykite šrifto dydį ir spalvą

Nustatyti portion_format.font_height dydžiui (taškais) ir naudoti fill_format spalvai.

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) priima reikšmes 0–255 kiekvienam kanalui.


Žingsnis 6: Keli Portion vienoje pastraipoje

Vienas pastraipa gali turėti kelias dalis su skirtingu formatavimu. Pridėkite naują Portion į pastraipos portions kolekciją:

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)

Dažnos problemos ir sprendimai

Tekstas lieka juodas net po spalvos nustatymo

Įsitikinkite fill_format.fill_type = FillType.SOLID yra nustatytas prieš priskiriant spalvą. Nustatant užpildymo tipą, spalvos pakeitimas gali neturėti jokio poveikio.

NullableBool.TRUE prieš True

portion_format.font_bold tikisi NullableBool.TRUE, o ne Python True. Priskiriant Python True gali sukelti TypeError arba tyliai nieko nedaryti, priklausomai nuo susiejimo.

Šriftas neatsiranda išsaugotame faile

Ši latin_font savybė nustato lotynišką šriftų šeimą. Jei nenustatyta, naudojamas pristatymo temos šriftas. Pasirinktiniai šriftai turi būti įterpti arba prieinami peržiūros įrenginyje.


Dažnai užduodami klausimai

Kaip pakeisti šrifto šeimą?

Nustatyti portion_format.latin_font:

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

FontData priima šrifto šeimos pavadinimą kaip eilutę.

Kaip nustatyti pastraipos lygiavimą?

Naudoti paragraph_format.alignment:

from aspose.slides_foss import TextAlignment

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

Palaikomos reikšmės: LEFT, CENTER, RIGHT, JUSTIFY.

Kaip nustatyti tarpą tarp eilučių?

Naudoti paragraph_format.space_before (taškai prieš pastraipą) arba paragraph_format.space_after taškai po pastraipos:

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

Žr. taip pat

 Lietuvių