Aplicar o cambiar diseños de diapositiva en Python
Resumen
Un diseño de diapositiva define la disposición de los cuadros de marcador de posición y el formato del contenido en una diapositiva. Controla qué marcadores de posición están disponibles y dónde aparecen. Los diseños de diapositiva le ayudan a crear presentaciones rápida y consistentemente, ya sea que esté creando algo sencillo o más complejo. Algunos de los diseños de diapositiva más comunes en PowerPoint incluyen:
Diseño de diapositiva de título – Incluye dos marcadores de posición de texto: uno para el título y otro para el subtítulo.
Diseño de título y contenido – Presenta un marcador de posición de título más pequeño en la parte superior y uno más grande debajo para el contenido principal (texto, viñetas, gráficos, imágenes y más).
Diseño en blanco – No contiene marcadores de posición, dándole control total para diseñar la diapositiva desde cero.
Los diseños de diapositiva forman parte de una diapositiva maestra, que es la diapositiva de nivel superior que define los estilos de diseño para la presentación. Puede acceder y modificar las diapositivas de diseño a través de la diapositiva maestra, ya sea por su tipo, nombre o ID único. Alternativamente, puede editar una diapositiva de diseño específica directamente dentro de la presentación.
Para trabajar con diseños de diapositiva en Aspose.Slides for Python, puede usar:
- Propiedades como layout_slides y masters bajo la clase Presentation
- Tipos como LayoutSlide, MasterLayoutSlideCollection, LayoutPlaceholderManager y LayoutSlideHeaderFooterManager
Info
Para obtener más información sobre el uso de diapositivas maestras, consulte el artículo Administrar diapositivas maestras de PowerPoint en Python.Agregar diseños de diapositiva a presentaciones
Para personalizar la apariencia y la estructura de sus diapositivas, puede que necesite agregar nuevos diseños a una presentación. Aspose.Slides for Python le permite comprobar si un diseño específico ya existe, agregar uno nuevo si es necesario y usarlo para insertar diapositivas basadas en ese diseño.
- Cree una instancia de la clase Presentation.
- Acceda a la MasterLayoutSlideCollection.
- Verifique si el diseño de diapositiva deseado ya existe en la colección. Si no, añada el diseño que necesita.
- Agregue una diapositiva en blanco basada en el nuevo diseño.
- Guarde la presentación.
El siguiente código Python muestra cómo agregar un diseño de diapositiva a una presentación de PowerPoint:
import aspose.slides as slides
# Instanciar la clase Presentation para abrir el archivo de presentación.
with slides.Presentation("sample.pptx") as presentation:
# Recorrer los tipos de diapositivas de diseño para seleccionar una diapositiva de diseño.
layout_slides = presentation.masters[0].layout_slides
layout_slide = layout_slides.get_by_type(slides.SlideLayoutType.TITLE_AND_OBJECT)
if layout_slide is None:
layout_slide = layout_slides.get_by_type(slides.SlideLayoutType.TITLE)
if layout_slide is None:
# Una situación en la que la presentación no contiene todos los tipos de diseño.
# El archivo de presentación contiene solo los tipos de diseño Blank y Custom.
# Sin embargo, las diapositivas de diseño con tipos personalizados pueden tener nombres reconocibles,
# como "Title", "Title and Content", etc., que pueden usarse para la selección de la diapositiva de diseño.
# También puede basarse en un conjunto de tipos de formas de marcador de posición.
# Por ejemplo, una diapositiva Title debería tener solo el tipo de marcador de posición Title, y así sucesivamente.
for title_and_object_layout_slide in layout_slides:
if title_and_object_layout_slide.name == "Title and Object":
layout_slide = title_and_object_layout_slide
break
if layout_slide is None:
for title_layout_slide in layout_slides:
if title_layout_slide.name == "Title":
layout_slide = title_layout_slide
break
if layout_slide is None:
layout_slide = layout_slides.get_by_type(slides.SlideLayoutType.BLANK)
if layout_slide is None:
layout_slide = layout_slides.Add(slides.SlideLayoutType.TITLE_AND_OBJECT, "Title and Object")
# Add an empty slide using the added layout slide.
presentation.slides.insert_empty_slide(0, layout_slide)
# Save the presentation to disk.
presentation.save("output.pptx", slides.export.SaveFormat.PPTX)
Eliminar diseños de diapositiva no utilizados
Aspose.Slides proporciona el método remove_unused_layout_slides de la clase Compress para permitirle eliminar diseños de diapositiva no deseados y no utilizados.
El siguiente código Python muestra cómo eliminar un diseño de diapositiva de una presentación de PowerPoint:
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
slides.lowcode.Compress.remove_unused_layout_slides(presentation)
presentation.save("output.pptx", slides.export.SaveFormat.PPTX)
Agregar marcadores de posición a diseños de diapositiva
Aspose.Slides proporciona la propiedad LayoutSlide.placeholder_manager, que le permite agregar nuevos marcadores de posición a un diseño de diapositiva.
Este administrador contiene métodos para los siguientes tipos de marcadores de posición:
| Marcador de posición de PowerPoint | Método de LayoutPlaceholderManager |
|---|---|
![]() |
add_content_placeholder(x: float, y: float, width: float, height: float) |
![]() |
add_vertical_content_placeholder(x: float, y: float, width: float, height: float) |
![]() |
add_text_placeholder(x: float, y: float, width: float, height: float) |
![]() |
add_vertical_text_placeholder(x: float, y: float, width: float, height: float) |
![]() |
add_picture_placeholder(x: float, y: float, width: float, height: float) |
![]() |
add_chart_placeholder(x: float, y: float, width: float, height: float) |
![]() |
add_table_placeholder(x: float, y: float, width: float, height: float) |
![]() |
add_smart_art_placeholder(x: float, y: float, width: float, height: float) |
![]() |
add_media_placeholder(x: float, y: float, width: float, height: float) |
![]() |
add_online_image_placeholder(x: float, y: float, width: float, height: float) |
El siguiente código Python muestra cómo agregar nuevas formas de marcador de posición al diseño en blanco:
import aspose.slides as slides
with slides.Presentation() as presentation:
# Obtener la diapositiva de diseño en blanco.
layout = presentation.layout_slides.get_by_type(slides.SlideLayoutType.BLANK)
# Obtener el administrador de marcadores de posición de la diapositiva de diseño.
placeholder_manager = layout.placeholder_manager
# Añadir diferentes marcadores de posición a la diapositiva de diseño en blanco.
placeholder_manager.add_content_placeholder(20, 20, 310, 270)
placeholder_manager.add_vertical_text_placeholder(350, 20, 350, 270)
placeholder_manager.add_chart_placeholder(20, 310, 310, 180)
placeholder_manager.add_table_placeholder(350, 310, 350, 180)
# Añadir una nueva diapositiva con el diseño en blanco.
new_slide = presentation.slides.add_empty_slide(layout)
presentation.save("placeholders.pptx", slides.export.SaveFormat.PPTX)
El resultado:

Establecer visibilidad del pie de página para un diseño de diapositiva
En presentaciones de PowerPoint, los elementos de pie de página como la fecha, el número de diapositiva y el texto personalizado pueden mostrarse u ocultarse según el diseño de la diapositiva. Aspose.Slides for Python le permite controlar la visibilidad de estos marcadores de posición de pie de página. Esto es útil cuando desea que ciertos diseños muestren información de pie de página mientras que otros se mantengan limpios y minimalistas.
- Cree una instancia de la clase Presentation.
- Obtenga una referencia al diseño de diapositiva por su índice.
- Establezca el marcador de posición del pie de página como visible.
- Establezca el marcador de posición del número de diapositiva como visible.
- Establezca el marcador de posición de fecha y hora como visible.
- Guarde la presentación.
El siguiente código Python muestra cómo establecer la visibilidad del pie de página de una diapositiva y realizar tareas relacionadas:
import aspose.slides as slides
with slides.Presentation("sample.pptx") as presentation:
header_footer_manager = presentation.layout_slides[0].header_footer_manager
if not header_footer_manager.is_footer_visible:
header_footer_manager.set_footer_visibility(True)
if not header_footer_manager.is_slide_number_visible:
header_footer_manager.set_slide_number_visibility(True)
if not header_footer_manager.is_date_time_visible:
header_footer_manager.set_date_time_visibility(True)
header_footer_manager.set_footer_text("Footer text")
header_footer_manager.set_date_time_text("Date and time text")
presentation.save("output.ppt", slides.export.SaveFormat.PPT)
Establecer visibilidad del pie de página hijo para una diapositiva
En presentaciones de PowerPoint, los elementos de pie de página como la fecha, el número de diapositiva y el texto personalizado pueden controlarse a nivel de diapositiva maestra para garantizar consistencia en todas las diapositivas de diseño. Aspose.Slides for Python le permite establecer la visibilidad y el contenido de estos marcadores de posición de pie de página en la diapositiva maestra y propagar estos ajustes a todas las diapositivas de diseño hijas. Esta abordagem garantiza información de pie de página uniforme en toda la presentación.
- Cree una instancia de la clase Presentation.
- Obtenga una referencia a la diapositiva maestra por su índice.
- Establezca los marcadores de posición de pie de página de la maestra y de todas sus hijas como visibles.
- Establezca los marcadores de posición de número de diapositiva de la maestra y de todas sus hijas como visibles.
- Establezca los marcadores de posición de fecha y hora de la maestra y de todas sus hijas como visibles.
- Guarde la presentación.
El siguiente código Python demuestra esta operación:
import aspose.slides as slides
with slides.Presentation("presentation.pptx") as presentation:
header_footer_manager = presentation.masters[0].header_footer_manager
header_footer_manager.set_footer_and_child_footers_visibility(True)
header_footer_manager.set_slide_number_and_child_slide_numbers_visibility(True)
header_footer_manager.set_date_time_and_child_date_times_visibility(True)
header_footer_manager.set_footer_and_child_footers_text("Footer text")
header_footer_manager.set_date_time_and_child_date_times_text("Date and time text")
presentation.save("output.pptx", slides.export.SaveFormat.PPTX)
Preguntas frecuentes
¿Cuál es la diferencia entre una diapositiva maestra y una diapositiva de diseño?
Una diapositiva maestra define el tema general y el formato predeterminado, mientras que las diapositivas de diseño definen disposiciones específicas de marcadores de posición para diferentes tipos de contenido.
¿Puedo copiar una diapositiva de diseño de una presentación a otra?
Sí, puede clonar una diapositiva de diseño de la colección layout_slides de una presentación e insertarla en otra usando el método add_clone.
¿Qué ocurre si elimino una diapositiva de diseño que aún está siendo usada por una diapositiva?
Si intenta eliminar una diapositiva de diseño que aún es referenciada por al menos una diapositiva en la presentación, Aspose.Slides lanzará una PptxEditException. Para evitarlo, use remove_unused_layout_slides, que elimina de forma segura solo los diseños que no están en uso.









