Ako formátovať text v Python
Aspose.Slides FOSS for Python provides fine-grained text formatting through the PortionFormat trieda. A Portion je najmenšia nezávislá jednotka textu; zodpovedá jednému formátovaciemu úseku v odstavci. Tento sprievodca ukazuje, ako použiť tučné, kurzívne, veľkosť písma a farebné formátovanie textu v prezentácii.
Postupný návod
Krok 1: Nainštalujte balík
pip install aspose-slides-fossKrok 2: Pridajte tvar s textovým rámcom
Pred formátovaním textu musí tvar obsahovať TextFrame. Použite shape.add_text_frame() na vytvorenie jedného.
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: Získajte prístup k TextFrame
shape.add_text_frame() vracia TextFrame objekt. Môžete ho tiež neskôr získať pomocou shape.text_frame.
tf = shape.text_frame # if the frame already exists
tf = shape.add_text_frame("") # creates a new frameA TextFrame obsahuje zoznam Paragraph objektov (tf.paragraphs). Každý Paragraph obsahuje Portion objektov (paragraph.portions).
Krok 4: Použite 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
Nastaviť portion_format.font_height pre veľkosť (v bodoch) a použiť 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 odstavci
Jeden odsek môže obsahovať viacero častí s rôznym formátovaním. Pridajte novú Portion do odseku portions kolekciu:
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 zostáva čierny aj po nastavení farby
Zabezpečte fill_format.fill_type = FillType.SOLID je nastavené pred priradením farby. Bez nastavenia typu výplne môže zmena farby nemajú žiadny účinok.
NullableBool.TRUE vs True
portion_format.font_bold očakáva NullableBool.TRUE, nie Python True. Priraďovanie Python True môže vyvolať TypeError alebo ticho nič neurobí v závislosti od väzby.
Písmo sa v uloženom súbore neobjavuje.
Tá latin_font vlastnosť nastavuje latinskú rodinu písma. 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 prijíma 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.CENTERPodporované hodnoty: LEFT, CENTER, RIGHT, JUSTIFY.
Ako nastaviť riadkovanie?
Použiť 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