Функции и возможности
Функции и возможности
Aspose.Slides FOSS for Python provides a broad set of capabilities for working with PowerPoint .pptx файлы программно. Эта страница перечисляет все поддерживаемые области функций с типичными примерами кода.
Ввод‑вывод презентаций
Откройте существующий .pptx файл или создайте новый, затем сохраните обратно в формате PPTX.
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
# Open an existing presentation
with slides.Presentation("input.pptx") as prs:
print(f"Slide count: {len(prs.slides)}")
prs.save("output.pptx", SaveFormat.PPTX)
# Create a new presentation (starts with one blank slide)
with slides.Presentation() as prs:
prs.save("new.pptx", SaveFormat.PPTX)Примечание: PPTX — единственный поддерживаемый формат сохранения. Экспорт в PDF, HTML, SVG или изображения недоступен.
Неизвестные XML‑части в исходном файле сохраняются дословно при сохранении, поэтому открытие и повторное сохранение a .pptx никогда не удалит содержимое, которое библиотека ещё не понимает.
Управление слайдами
Добавляйте, удаляйте, клонируйте и переупорядочивайте слайды.
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
with slides.Presentation() as prs:
# Access the first slide
slide = prs.slides[0]
# Add an additional blank slide at the end
prs.slides.add_empty_slide(prs.layout_slides[0])
print(f"Total slides: {len(prs.slides)}")
prs.save("multi-slide.pptx", SaveFormat.PPTX)Фигуры
Добавляйте AutoShapes, PictureFrames, таблицы и соединители на слайд.
AutoShapes
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]
# Add a rectangle at (x=50, y=50) with width=300, height=100
shape = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 50, 50, 300, 100)
shape.add_text_frame("Aspose.Slides FOSS")
prs.save("shapes.pptx", SaveFormat.PPTX)Таблицы
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
with slides.Presentation() as prs:
slide = prs.slides[0]
# Column widths and row heights in points
col_widths = [120.0, 120.0, 120.0]
row_heights = [40.0, 40.0, 40.0]
table = slide.shapes.add_table(50, 50, col_widths, row_heights)
table.rows[0][0].text_frame.text = "Product"
table.rows[0][1].text_frame.text = "Quantity"
table.rows[0][2].text_frame.text = "Price"
prs.save("table.pptx", SaveFormat.PPTX)Соединители
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)
box2 = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 350, 100, 150, 60)
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
conn.end_shape_connected_to = box2
conn.end_shape_connection_site_index = 1 # left side
prs.save("connector.pptx", SaveFormat.PPTX)Форматирование текста
Форматируйте текст на уровне абзаца и символа с помощью PortionFormat.
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("Bold blue heading")
fmt = tf.paragraphs[0].portions[0].portion_format
fmt.font_height = 28
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("text.pptx", SaveFormat.PPTX)NullableBool.TRUE устанавливает свойство явно; NullableBool.NOT_DEFINED наследуется от шаблона слайда.
Типы заливки
Применяйте сплошные, градиентные, узорные или изображённые заливки к фигурам.
import aspose.slides_foss as slides
from aspose.slides_foss import ShapeType, 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, 300, 150)
# Solid fill
shape.fill_format.fill_type = FillType.SOLID
shape.fill_format.solid_fill_color.color = Color.from_argb(255, 30, 120, 200)
prs.save("fill.pptx", SaveFormat.PPTX)Визуальные эффекты
Применяйте внешнюю тень, сияние, мягкий край, размытие, отражение и внутреннюю тень к фигурам.
Свойства эффекта доступны через shape.effect_format. Установить outer_shadow_effect, glow_effect, soft_edge_effect, blur_effect, reflection_effect, или inner_shadow_effect для независимой настройки каждого.
3D Formatting
Примените 3D-скос, камеру, световую установку, материал и глубину выдавливания через shape.three_d_format. Это управляет визуальной глубиной и моделью освещения при отрисовке фигур в PPTX‑просмотрщиках, поддерживающих 3D‑эффекты.
Заметки докладчика
Прикрепляйте заметки к любому слайду с помощью notes_slide_manager.
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
with slides.Presentation() as prs:
notes = prs.slides[0].notes_slide_manager.add_notes_slide()
notes.notes_text_frame.text = "Key talking point: emphasize the ROI benefit."
prs.save("notes.pptx", SaveFormat.PPTX)Комментарии
Добавляйте ветвящиеся комментарии с информацией об авторе и положением на слайде.
import aspose.slides_foss as slides
from aspose.slides_foss.drawing import PointF
from aspose.slides_foss.export import SaveFormat
from datetime import datetime
with slides.Presentation() as prs:
author = prs.comment_authors.add_author("Jane Smith", "JS")
slide = prs.slides[0]
author.comments.add_comment(
"Please verify this data before the presentation.",
slide,
PointF(2.0, 2.0),
datetime.now()
)
prs.save("comments.pptx", SaveFormat.PPTX)Встроенные изображения
Вставьте изображение из пути к файлу в презентацию и добавьте его на слайд в виде PictureFrame.
import aspose.slides_foss as slides
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(
slides.ShapeType.RECTANGLE, 50, 50, 200, 150, image
)
prs.save("with-image.pptx", SaveFormat.PPTX)Свойства документа
Чтение и запись основных, app и пользовательских свойств документа.
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
with slides.Presentation() as prs:
props = prs.document_properties
# Core properties
props.title = "Q1 Results"
props.author = "Finance Team"
props.subject = "Quarterly Review"
props.keywords = "Q1, finance, results"
# Custom property
props.set_custom_property_value("ReviewedBy", "Legal Team")
prs.save("deck.pptx", SaveFormat.PPTX)Известные ограничения
Следующие области вызывают NotImplementedError и недоступны в этой версии:
| Область | Статус |
|---|---|
| Диаграммы | Не реализовано |
| SmartArt | Не реализовано |
| Анимации и переходы | Не реализовано |
| Экспорт PDF / HTML / SVG / изображений | Не реализовано (только PPTX) |
| VBA‑макросы | Не реализовано |
| Цифровые подписи | Не реализовано |
| Гиперссылки и настройки действий | Не реализовано |
| OLE‑объекты | Не реализовано |
| Математический текст | Не реализовано |
См. также
- Начало работы: Установка и первый скрипт
- Справочник API: Справочник классов и методов
- Руководства How‑To: Статьи, ориентированные на задачи