Как добавить комментарии в PowerPoint с помощью Python
Aspose.Slides FOSS for Python поддерживает два механизма аннотации:
- Threaded comments: прикреплены к слайду в определённом месте, видимы в панели Review PowerPoint
- Speaker notes: текст, привязанный к каждому слайду, видимый в режиме Presenter View и в панели Notes
Требования
pip install aspose-slides-fossДобавить комментарий
Комментарии принадлежат объекту author. Сначала создайте автора, затем добавьте комментарии через author.comments:
from aspose.slides_foss.drawing import PointF
from datetime import datetime
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
with slides.Presentation() as prs:
# Create a comment author with name and initials
author = prs.comment_authors.add_author("Jane Smith", "JS")
slide = prs.slides[0]
# Add a comment at (2.0, 2.0) inches from the slide top-left corner
author.comments.add_comment(
"Please review the figures on this slide",
slide,
PointF(2.0, 2.0),
datetime.now(),
)
prs.save("commented.pptx", SaveFormat.PPTX)Координаты PointF указаны в дюймах от верхнего левого угла слайда. Многократные вызовы add_comment() создают цепочку потоковых комментариев от того же автора.
Несколько авторов и комментариев
from aspose.slides_foss.drawing import PointF
from datetime import datetime
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
with slides.Presentation() as prs:
author1 = prs.comment_authors.add_author("Alice Brown", "AB")
author2 = prs.comment_authors.add_author("Bob Davis", "BD")
slide = prs.slides[0]
author1.comments.add_comment(
"Initial draft: needs revision",
slide, PointF(1.0, 1.0), datetime.now()
)
author2.comments.add_comment(
"Approved after changes",
slide, PointF(3.0, 1.0), datetime.now()
)
prs.save("multi-author.pptx", SaveFormat.PPTX)Прочитать комментарии из существующего файла
import aspose.slides_foss as slides
with slides.Presentation("commented.pptx") as prs:
for author in prs.comment_authors:
print(f"Author: {author.name} ({author.initials})")
for comment in author.comments:
print(f" Slide {comment.slide.slide_number}: {comment.text}")Добавить заметки докладчика к слайду
Заметки к выступлению добавляются через slide.notes_slide_manager:
from aspose.slides_foss import ShapeType
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
with slides.Presentation() as prs:
slide = prs.slides[0]
slide.shapes.add_auto_shape(
ShapeType.RECTANGLE, 50, 50, 600, 300
).add_text_frame("Main slide content")
# Create the notes slide and write text
notes = slide.notes_slide_manager.add_notes_slide()
notes.notes_text_frame.text = (
"Mention the Q3 revenue increase. Emphasize the 24% YoY growth."
)
prs.save("with-notes.pptx", SaveFormat.PPTX)Добавить заметки к нескольким слайдам
from aspose.slides_foss import ShapeType
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
note_texts = [
"Opening: introduce the agenda and set expectations.",
"Key metrics: emphasize Q4 results and growth trajectory.",
"Closing: summarize and call to action.",
]
with slides.Presentation() as prs:
layout = prs.slides[0].layout_slide
prs.slides.add_empty_slide(layout)
prs.slides.add_empty_slide(layout)
for i, slide in enumerate(prs.slides):
slide.shapes.add_auto_shape(
ShapeType.RECTANGLE, 50, 50, 600, 300
).add_text_frame(f"Slide {i + 1}")
n = slide.notes_slide_manager.add_notes_slide()
n.notes_text_frame.text = note_texts[i]
prs.save("all-notes.pptx", SaveFormat.PPTX)Проверить, существуют ли уже заметки
notes_slide_manager.notes_slide возвращает None, если слайд заметок не был создан:
import aspose.slides_foss as slides
with slides.Presentation("existing.pptx") as prs:
for i, slide in enumerate(prs.slides):
existing = slide.notes_slide_manager.notes_slide
if existing:
print(f"Slide {i + 1}: {existing.notes_text_frame.text[:60]}")
else:
print(f"Slide {i + 1}: no notes")