使用评论和演讲者备注 — Aspose.Slides FOSS for Python
Aspose.Slides FOSS for Python 支持两种注释类型:threaded slide comments(在审阅模式下可见)和speaker notes(在演示者视图和备注窗格中可见)。
线程式评论
评论附加到幻灯片并与作者关联。prs.comment_authors 集合管理所有作者;每个作者都有 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 initials
author = prs.comment_authors.add_author("Jane Smith", "JS")
slide = prs.slides[0]
# Add a comment at position (2.0, 2.0) inches from the slide top-left
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", slide, PointF(1.0, 1.0), datetime.now())
author2.comments.add_comment("Approved", 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" [{comment.slide.slide_number}] {comment.text}")演讲者备注
演讲者备注以每张幻灯片为单位存储在 NotesSlide 对象中。通过 slide.notes_slide_manager 访问它。
为幻灯片添加演讲者备注
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(slides.ShapeType.RECTANGLE, 50, 50, 400, 200)
# Create the notes slide and set text
notes = slide.notes_slide_manager.add_notes_slide()
notes.notes_text_frame.text = "Mention the Q3 revenue increase on this slide. Emphasize the 24% 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
with slides.Presentation() as prs:
slide = prs.slides[0]
slide.shapes.add_auto_shape(ShapeType.RECTANGLE, 100, 100, 500, 250).add_text_frame("Main Content")
notes = slide.notes_slide_manager.add_notes_slide()
notes.notes_text_frame.text = "These are the speaker notes for this slide."
prs.save("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_notes = slide.notes_slide_manager.notes_slide
if existing_notes:
text = existing_notes.notes_text_frame.text
print(f"Slide {i + 1} notes: {text[:60]}...")
else:
print(f"Slide {i + 1}: no notes")为多个幻灯片添加备注
from aspose.slides_foss import ShapeType
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
note_texts = [
"Opening remarks: introduce the agenda.",
"Key metrics: emphasize Q4 results.",
"Closing: call to action.",
]
with slides.Presentation() as prs:
# Add slides 2 and 3
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)