Як додати коментарі до PowerPoint у Python

Як додати коментарі до PowerPoint у Python

Aspose.Slides FOSS for Python підтримує два механізми анотування:

  • Threaded comments: прикріплені до слайда в певному положенні, видимі у панелі Огляд у PowerPoint
  • Speaker notes: текст для кожного слайда, видимий у режимі Презентера та панелі Примітки

Вимоги

pip install aspose-slides-foss

Додати коментар

Коментарі належать об’єкту author. Спочатку створіть 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")

Дивіться також

 Українська