Πώς να μορφοποιήσετε κείμενο σε Python
Το Aspose.Slides FOSS for Python παρέχει λεπτομερή μορφοποίηση κειμένου μέσω της κλάσης PortionFormat. Ένα Portion είναι η μικρότερη ανεξάρτητη μονάδα κειμένου· αντιστοιχεί σε μία ενιαία σειρά μορφοποίησης μέσα σε μια παράγραφο. Αυτός ο οδηγός δείχνει πώς να εφαρμόσετε έντονη, πλάγια, μέγεθος γραμματοσειράς και χρωματική μορφοποίηση στο κείμενο μιας παρουσίασης.
Οδηγός βήμα-βήμα
Βήμα 1: Εγκατάσταση του πακέτου
pip install aspose-slides-fossΒήμα 2: Προσθήκη Σχήματος με Πλαίσιο Κειμένου
Πριν μορφοποιήσετε το κείμενο, ένα σχήμα πρέπει να περιέχει ένα TextFrame. Χρησιμοποιήστε shape.add_text_frame() για να δημιουργήσετε ένα.
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: Πρόσβαση στο TextFrame
shape.add_text_frame() επιστρέφει το αντικείμενο TextFrame. Μπορείτε επίσης να το ανακτήσετε αργότερα μέσω shape.text_frame.
tf = shape.text_frame # if the frame already exists
tf = shape.add_text_frame("") # creates a new frameΈνα TextFrame περιέχει μια λίστα από Paragraph αντικείμενα (tf.paragraphs). Κάθε Paragraph περιέχει Portion αντικείμενα (paragraph.portions).
Βήμα 4: Εφαρμογή έντονης και πλάγιας μορφοποίησης
Χρησιμοποιήστε portion_format.font_bold και portion_format.font_italic. Αυτές οι ιδιότητες δέχονται NullableBool.TRUE, NullableBool.FALSE ή NullableBool.NOT_DEFINED (κληρονομούν από 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)Βήμα 5: Ορισμός μεγέθους γραμματοσειράς και χρώματος
Ορίστε portion_format.font_height για το μέγεθος (σε σημεία) και χρησιμοποιήστε fill_format για το χρώμα.
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) αποδέχεται τιμές 0–255 για κάθε κανάλι.
Βήμα 6: Πολλαπλά Τμήματα σε Μία Παράγραφο
Μία μόνο παράγραφος μπορεί να περιέχει πολλαπλά τμήματα με διαφορετική μορφοποίηση. Προσθέστε ένα νέο Portion στη συλλογή portions μιας παραγράφου:
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)Κοινά Προβλήματα και Διορθώσεις
Το κείμενο εμφανίζεται μαύρο ακόμη και μετά τον ορισμό του χρώματος
Βεβαιωθείτε ότι το fill_format.fill_type = FillType.SOLID είναι ορισμένο πριν την ανάθεση του χρώματος. Χωρίς τον καθορισμό του τύπου γεμίσματος, η αλλαγή χρώματος μπορεί να μην έχει αποτέλεσμα.
NullableBool.TRUE εναντίον True
portion_format.font_bold αναμένει NullableBool.TRUE, όχι το Python True. Η ανάθεση του Python True μπορεί να προκαλέσει ένα TypeError ή να μην κάνει τίποτα σιωπηρά, ανάλογα με τη σύνδεση.
Η γραμματοσειρά δεν εμφανίζεται στο αποθηκευμένο αρχείο
Η ιδιότητα latin_font ορίζει την οικογένεια γραμματοσειρών Latin. Εάν δεν οριστεί, χρησιμοποιείται η γραμματοσειρά του θέματος παρουσίασης. Οι προσαρμοσμένες γραμματοσειρές πρέπει να ενσωματωθούν ή να είναι διαθέσιμες στο μηχάνημα προβολής.
Συχνές Ερωτήσεις
Πώς αλλάζω την οικογένεια γραμματοσειράς;
Σύνολο portion_format.latin_font:
fmt.latin_font = slides.FontData("Arial")FontData δέχεται το όνομα οικογένειας γραμματοσειράς ως συμβολοσειρά.
Πώς μπορώ να ορίσω την ευθυγράμμιση παραγράφου;
Χρησιμοποιήστε paragraph_format.alignment:
from aspose.slides_foss import TextAlignment
tf.paragraphs[0].paragraph_format.alignment = TextAlignment.CENTERΥποστηριζόμενες τιμές: LEFT, CENTER, RIGHT, JUSTIFY.
Πώς ρυθμίζω το διάστημα γραμμής;
Χρησιμοποιήστε paragraph_format.space_before (σημεία πριν από την παράγραφο) ή paragraph_format.space_after (σημεία μετά την παράγραφο):
tf.paragraphs[0].paragraph_format.space_before = 12 # 12pt before
tf.paragraphs[0].paragraph_format.space_after = 6 # 6pt after