Cómo agregar imágenes a diapositivas de PowerPoint en Python

Cómo agregar imágenes a diapositivas de PowerPoint en Python

Las imágenes en Aspose.Slides FOSS se incrustan como marcos de imagen, formas que contienen una imagen y pueden posicionarse, redimensionarse y estilizarse como cualquier otra forma. Los datos de la imagen se almacenan una sola vez en la colección prs.images y son referenciados por el marco.


Requisitos previos

pip install aspose-slides-foss

Agregar una imagen desde un archivo

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)

La firma add_picture_frame:

add_picture_frame(shape_type, x, y, width, height, image) → PictureFrame

Todas las dimensiones están en puntos (1 punto = 1/72 pulgada). Para una diapositiva estándar de 13.33 × 7.5 pulgadas, el espacio de coordenadas es 960 × 540 puntos.


Agregar una imagen desde bytes

Si ya tienes la imagen como bytes (p. ej., descargada de una URL o leída de una base de datos):

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)

Controlar el modo de relleno

El picture_fill_format en un PictureFrame controla cómo la imagen llena los límites del marco:

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)
PictureFillModeComportamiento
STRETCHEscalar la imagen para llenar el marco, ignorando la relación de aspecto
TILERepetir la imagen como un patrón en mosaico
TILE_FLIPMosaico con volteos horizontales/verticales alternados

Agregar varias imágenes a diferentes diapositivas

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)

Contar imágenes en una presentación existente

import aspose.slides_foss as slides

with slides.Presentation("with-image.pptx") as prs:
    print(f"Presentation contains {len(prs.images)} image(s)")

La colección prs.images se comparte en todas las diapositivas: los mismos bytes de imagen se almacenan una sola vez, incluso si el marco de imagen aparece en varias diapositivas.


Ver también

 Español