Введение
Aspose.Slides FOSS for Python is now available on PyPI: a free, MIT-licensed library for creating, reading, and editing PowerPoint .pptx файлы полностью в Python, без зависимости от Microsoft Office или любого проприетарного runtime.
Библиотека предназначена для разработчиков, которым необходимо программно генерировать или манипулировать файлами презентаций: автоматизировать наборы слайдов из данных, извлекать текст и метаданные из загруженных PPTX‑файлов, создавать конвейеры отчетности на основе презентаций или встраивать создание презентаций в веб‑приложения. Потому что aspose-slides-foss это чистый Python только с lxml в качестве зависимости, он разворачивается одинаково на Windows, macOS, Linux и в Docker‑контейнерах.
Ключевые возможности
- Полная поддержка PPTX round‑trip: Откройте любой
.pptxфайл, измените его содержимое и сохраните обратно, не теряя неизвестные XML‑части, которые библиотека пока не понимает. - Управление слайдами:Добавляйте, удаляйте и перебирайте слайды с помощью
prs.slides; презентация начинается с одного пустого слайда послеslides.Presentation(). - AutoShapes, таблицы и соединители: Вставляйте фигуры через
slide.shapes.add_auto_shape(), табличные данные черезslide.shapes.add_table(), и визуальные соединители между фигурами черезslide.shapes.add_connector(). - Rich text форматирование: Форматируйте текст на уровне символов с помощью
PortionFormat: размер шрифта, полужирный, курсив, подчеркивание и цвет ARGB черезFillType.SOLIDиColor.from_argb(). - Типы заливки: Применить
FillType.SOLID,GRADIENT,PATTERN, илиPICTUREзаливки к любой фигуре. - Визуальные эффекты: Внешняя тень, свечение, мягкий край, размытие, отражение и внутренняя тень через
shape.effect_format. - 3D formatting: Фаска, камера, система освещения, материал и глубина выдавливания через
shape.three_d_format. - Заметки докладчика: Прикрепить текст заметок к каждому слайду через
notes_slide_manager.add_notes_slide(). - Ветвящиеся комментарии: Добавить комментарии с метаданными автора и позицией слайда.
- Встроенные изображения: Встроить из пути к файлу, байтов или
io.BytesIOпотока. - Свойства документа: Чтение и запись основных, приложенных и пользовательских свойств.
Начало работы
Установите из PyPI. Python 3.10 или более поздняя версия требуется; lxml устанавливается автоматически.
pip install aspose-slides-foss
Создайте свою первую презентацию с фигурой и сохраните её:
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
from aspose.slides_foss import ShapeType
with slides.Presentation() as prs:
slide = prs.slides[0]
shape = slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 50, 50, 400, 120)
shape.add_text_frame("Hello from Aspose.Slides FOSS!")
prs.save("hello.pptx", SaveFormat.PPTX)
Всегда используйте Presentation внутри with блока; это гарантирует, что все внутренние ресурсы будут освобождены при выходе из блока.
Пример форматирования текста
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:
shape = prs.slides[0].shapes.add_auto_shape(ShapeType.RECTANGLE, 50, 50, 500, 150)
tf = shape.add_text_frame("Bold heading in corporate blue")
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("formatted.pptx", SaveFormat.PPTX)
Текущие ограничения
Следующие области вызывают NotImplementedError в этом выпуске:
- Диаграммы, SmartArt и OLE‑объекты
- Анимации и переходы слайдов
- Экспорт в PDF, HTML, SVG или форматы изображений
- Гиперссылки, настройки действий, макросы VBA и цифровые подписи
Неизвестные XML‑части, обнаруженные при загрузке, сохраняются дословно при сохранении, поэтому PPTX‑файлы, созданные другими инструментами, безопасно проходят цикл загрузки‑сохранения.