Hogyan adjunk hozzá alakzatokat a PowerPoint-hoz Pythonban
Aspose.Slides FOSS for Python támogatja az AutoShapes, Tables, Connectors és PictureFrames hozzáadását a prezentációs diákhoz. Minden alakzattípust a slide.shapes gyűjteményen keresztül adunk hozzá.
Lépésről‑lépésre útmutató
1. lépés: A csomag telepítése
pip install aspose-slides-fossEllenőrizze a telepítést:
import aspose.slides_foss as slides
print("Ready")2. lépés: Prezentáció létrehozása
Mindig használja Presentation-t kontextuskezelőként.
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
with slides.Presentation() as prs:
slide = prs.slides[0]
# ... add shapes ...
prs.save("output.pptx", SaveFormat.PPTX)3. lépés: AutoShape hozzáadása
slide.shapes.add_auto_shape(shape_type, x, y, width, height) egy alakzatot helyez el a megadott pozícióban és méretben (mind pontban). Használja a ShapeType állandókat az alakzat kiválasztá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]
# Rectangle
rect = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 50, 50, 300, 100)
rect.add_text_frame("Rectangle shape")
# Ellipse
ellipse = slide.shapes.add_auto_shape(ShapeType.ELLIPSE, 400, 50, 200, 100)
ellipse.add_text_frame("Ellipse shape")
prs.save("autoshapes.pptx", SaveFormat.PPTX)4. lépés: Táblázat hozzáadása
slide.shapes.add_table(x, y, col_widths, row_heights) táblát hoz létre a megadott pozíción. Az oszlopszélességek és sormagasságok pontértékek listái.
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
with slides.Presentation() as prs:
slide = prs.slides[0]
col_widths = [150.0, 150.0, 150.0]
row_heights = [40.0, 40.0, 40.0]
table = slide.shapes.add_table(50, 200, col_widths, row_heights)
# Set header row text
headers = ["Product", "Units", "Revenue"]
for col, text in enumerate(headers):
table.rows[0][col].text_frame.text = text
# Set data rows
rows = [
["Widget A", "120", "$2,400"],
["Widget B", "85", "$1,700"],
]
for row_idx, row_data in enumerate(rows):
for col, text in enumerate(row_data):
table.rows[row_idx + 1][col].text_frame.text = text
prs.save("table.pptx", SaveFormat.PPTX)5. lépés: Csatlakozó hozzáadása
A csatlakozók vizuálisan összekapcsolják a két alakzatot. Először hozza létre az alakzatokat, majd adjon hozzá egy csatlakozót, és állítsa be a kezdő- és végkapcsolási pontokat.
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]
box1 = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 50, 100, 150, 60)
box1.add_text_frame("Start")
box2 = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 350, 100, 150, 60)
box2.add_text_frame("End")
conn = slide.shapes.add_connector(ShapeType.BENT_CONNECTOR3, 0, 0, 10, 10)
conn.start_shape_connected_to = box1
conn.start_shape_connection_site_index = 3 # right side of box1
conn.end_shape_connected_to = box2
conn.end_shape_connection_site_index = 1 # left side of box2
prs.save("connector.pptx", SaveFormat.PPTX)A csatlakozási helyek indexei 0–3-ig vannak számozva egy téglalap esetén: felső=0, bal=1, alsó=2, jobb=3.
6. lépés: Képkeret hozzáadása
Ágyazz be egy képet, és add hozzá a diához PictureFrame. Olvasd be először a kép bájtjait, add azokat a prezentáció képgyűjteményéhez, majd hozd létre a keretet.
import aspose.slides_foss as slides
from aspose.slides_foss import ShapeType
from aspose.slides_foss.export import SaveFormat
with slides.Presentation() as prs:
with open("logo.png", "rb") as f:
image_data = f.read()
image = prs.images.add_image(image_data)
slide = prs.slides[0]
slide.shapes.add_picture_frame(
ShapeType.RECTANGLE, # bounding shape type
50, 50, # x, y in points
200, 150, # width, height in points
image
)
prs.save("with-image.pptx", SaveFormat.PPTX)Általános problémák és megoldások
Alakzat a látható diaterületen kívül jelenik meg
A diák alapértelmezés szerint 720 × 540 pont méretűek. A x vagy y értékek ezen határokon kívül a formát a diáról kívülre helyezik. Tartsa meg a x < 720 és y < 540 értékeket, és biztosítsa a x + width <= 720 és y + height <= 540 értékeket.
AttributeError: 'NoneType' object has no attribute 'text_frame'
add_auto_shape() közvetlenül visszaadja a shape objektumot. Ha None-t látod, ellenőrizd, hogy nem dobod‑e el a visszatérési értéket.
A táblázatcellában a szöveg üres a hozzárendelés után
A helyes tulajdonság a .text_frame.text (nem .text közvetlenül a cellán). A cellákat így érheti el: table.rows[row_index][col_index].text_frame.text = "value".
Gyakran Ismételt Kérdések
Hány alakzatot adhatok hozzá egy diára?
Nincs a könyvtár által előírt korlát. A gyakorlati korlátok a fájlmérettől és a cél PPTX megjelenítő képességétől függenek.
Módosíthatom egy alakzat pozícióját a hozzáadása után?
Igen. A add_auto_shape() által visszaadott shape objektumnak vannak x, y, width és height tulajdonságai, amelyeket beállíthat:
shape.x = 100
shape.y = 200
shape.width = 400
shape.height = 80Beállíthatom a forma körvonalának (szegélyének) színét?
Igen, a shape.line_format segítségével:
from aspose.slides_foss.drawing import Color
shape.line_format.fill_format.solid_fill_color.color = Color.from_argb(255, 200, 0, 0)Támogatottak a diagramok?
Nem. A diagramok, a SmartArt és az OLE‑objektumok nincsenek megvalósítva ebben a kiadásban, és NotImplementedError hibát váltanak ki.