PythonでPowerPointスライドに画像を追加する方法
Aspose.Slides FOSS の画像は picture frames として埋め込まれ、画像を保持し、他のシェイプと同様に位置指定、サイズ変更、スタイル設定が可能なシェイプです。画像データは prs.images コレクションに一度だけ保存され、フレームから参照されます。
前提条件
pip install aspose-slides-fossファイルから画像を追加
from aspose.slides_foss import ShapeType, PictureFillMode
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
with slides.Presentation() as prs:
slide = prs.slides[0]
# Load image into the presentation's image collection
with open("photo.jpg", "rb") as f:
img = prs.images.add_image(f.read())
# Add a picture frame at (x=50, y=50, width=400, height=300) in points
frame = slide.shapes.add_picture_frame(
ShapeType.RECTANGLE,
50, 50, 400, 300,
img,
)
prs.save("with-image.pptx", SaveFormat.PPTX)add_picture_frame の署名:
add_picture_frame(shape_type, x, y, width, height, image) → PictureFrameすべての寸法は points(1 point = 1/72 inch)です。標準的な13.33 × 7.5インチのスライドでは、座標空間は960 × 540 pointsです。
バイト配列から画像を追加
画像がすでにバイト形式である場合(例:URL からダウンロードしたり、データベースから読み取ったりした場合):
import aspose.slides_foss as slides
from aspose.slides_foss import ShapeType
from aspose.slides_foss.export import SaveFormat
image_bytes = open("logo.png", "rb").read() # or any bytes source
with slides.Presentation() as prs:
img = prs.images.add_image(image_bytes)
prs.slides[0].shapes.add_picture_frame(
ShapeType.RECTANGLE,
200, 100, 300, 200,
img,
)
prs.save("logo-slide.pptx", SaveFormat.PPTX)塗りつぶしモードを制御する
PictureFrame上のpicture_fill_formatは、画像がフレームの境界をどのように埋めるかを制御します:
from aspose.slides_foss import ShapeType, PictureFillMode
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
with slides.Presentation() as prs:
img = prs.images.add_image(open("texture.png", "rb").read())
frame = prs.slides[0].shapes.add_picture_frame(
ShapeType.RECTANGLE, 50, 50, 600, 350, img
)
# STRETCH: scale image to fill the frame exactly (default)
frame.picture_format.picture_fill_mode = PictureFillMode.STRETCH
# TILE: repeat the image in a grid pattern
# frame.picture_format.picture_fill_mode = PictureFillMode.TILE
prs.save("filled.pptx", SaveFormat.PPTX)PictureFillMode | 動作 |
|---|---|
STRETCH | アスペクト比を無視して画像をフレーム全体に拡大する |
TILE | 画像をタイルパターンとして繰り返す |
TILE_FLIP | 水平/垂直の反転を交互に行うタイル |
異なるスライドに複数の画像を追加
import os
from aspose.slides_foss import ShapeType
import aspose.slides_foss as slides
from aspose.slides_foss.export import SaveFormat
image_files = ["slide1.jpg", "slide2.jpg", "slide3.jpg"]
with slides.Presentation() as prs:
layout = prs.slides[0].layout_slide
# Ensure enough slides exist
while len(prs.slides) < len(image_files):
prs.slides.add_empty_slide(layout)
for i, path in enumerate(image_files):
if not os.path.exists(path):
continue
img = prs.images.add_image(open(path, "rb").read())
prs.slides[i].shapes.add_picture_frame(
ShapeType.RECTANGLE, 0, 0, 960, 540, img
)
prs.save("multi-image.pptx", SaveFormat.PPTX)既存のプレゼンテーション内の画像をカウントする
import aspose.slides_foss as slides
with slides.Presentation("with-image.pptx") as prs:
print(f"Presentation contains {len(prs.images)} image(s)")prs.images コレクションはすべてのスライドで共有されます: 画像フレームが複数のスライドに表示されても、同じ画像バイトは一度だけ保存されます。