¿Cómo crear y agregar diapositivas a presentaciones de PowerPoint con VBA?

Hace un par de días, un lector preguntó si había una manera de automatizar la creación de presentaciones de PowerPoint desde cero y luego agregar rápidamente diapositivas a esa presentación existente. Pensé que ese script podría estar en la lista de las macros de PowerPoint más útiles. 

Como indicamos anteriormente, PowerPoint no incluye una grabadora de macros (a diferencia de Excel y Word, que tienen grabadoras integradas para macros). Por lo tanto, nos quedamos con el viejo Visual Basic para aplicaciones que podemos usar para crear macros simples para automatizar PowerPoint. Existen otras alternativas para la automatización de PowerPoint, pero van más allá del alcance de este tutorial.

En el breve tutorial de hoy, repasaremos tres casos de uso diferentes:

  1. Nueva creación de presentación (en blanco o usando una plantilla)
  2. Agregue diapositivas a una presentación existente.
  3. Una combinación de los dos casos mencionados anteriormente (Crear desde cero y adición de diapositivas)

Empecemos.

Mira la cinta. Si no ve la entrada Desarrollador en el menú, antes de comenzar a codificar, deberá habilitar la pestaña Desarrollador.

Después de hacer que el menú Desarrollador sea visible en su Cinta, continúe y presione Desarrollador , luego presione el botón Visual Basic (o simplemente continúe y presione Alt + F11) para abrir el IDE de Visual Basic.

VBA para crear una presentación de PowerPoint

  1. En el Editor de VB, haga clic derecho en VBAProject y presione Insertar .
  2. Seleccione Módulo .
  3. Pegue el siguiente código en el módulo recién creado.
Sub CreatePresentation()
Dim NewPres as Presentation
Set NewPres = Presentations.Add
NewPres.SaveAs("MyPresentation.pptx")
End Sub
  1. Presiona Archivo y luego Guardar.
  2. Para ejecutar su código, presione Ejecutar y luego seleccione Ejecutar formulario de sub/usuario (o simplemente F5).
  3. Cierre el editor de VB.

VBA para insertar diapositivas

  1. En el Editor de VB, haga clic derecho en VBAProject y presione Insertar.
  2. Seleccionar módulo
  3. Pegue el siguiente código en el módulo recién creado.
Sub CreateSlide()
Dim NewSlide as Slide
'This statement ads a title slide
Set NewSlide = ActivePresentation.Slides.Add(Index:=1, Layout:=ppLayoutTitle)
'This statement adds a blank slide in the second place
Set NewSlide = ActivePresentation.Slides.Add(Index:=2, Layout:=ppLayoutBlank)
End Sub
  1. Presiona Archivo y luego Guardar.
  2. Para ejecutar su código, presione Ejecutar y luego seleccione Ejecutar formulario de sub/usuario (o simplemente F5).
  3. Cierre el editor de VB.

Macro para configurar una nueva presentación y agregar diapositivas

Eso sería simplemente mezclar los dos fragmentos descritos anteriormente.

Sub CreatePres_AddSlides()
Dim NewPres as Presentation
Dim NewSlide as Slide
Set NewPres = Presentations.Add
NewPres.SaveAs("MyPresentation.pptx")
' Title Slide
Set NewSlide = ActivePresentation.Slides.Add(Index:=1, Layout:=ppLayoutTitle)
'This statement adds a blank slide in the second place
Set NewSlide = ActivePresentation.Slides.Add(Index:=2, Layout:=ppLayoutBlank)
'Save the new PowerPoint file
NewPres.SaveAs("MyPresentation.pptx")
End Sub

A continuación, puede consultar nuestro tutorial sobre la creación programática de formas en PowerPoint con VBA

Generar una presentación de PowerPoint desde Excel

El último caso es que le gustaría crear una presentación de PowerPoint directamente desde una hoja de cálculo de Excel. Puede emplear la misma técnica desde Word y otras aplicaciones de Microsoft 365.

  • Vincule la hoja de cálculo al modelo de datos de PowerPoint (desde Herramientas>>Referencias)
  • Inserte un botón en su hoja de cálculo de Excel (Desarrollador >> Insertar y luego elija un botón de comando).
  • Inserte el código VBA a continuación en su proyecto VBA de hoja de cálculo (directamente en la hoja o en un módulo VBA)
  • Modifique el script según sea necesario.
  • Ejecutar (pulsar F5) y probar el resultado.
Sub CreatePresentationFromExcel()


Dim MyPPt As PowerPoint.Application
Dim NewPres As PowerPoint.Presentation
Dim NewSlide As Slide
Set MyPPt = CreateObject("PowerPoint.Application")

Set NewPres = MyPPt.Presentations.Add
Set NewSlide = MyPPt.ActivePresentation.Slides.Add(Index:=1, Layout:=ppLayoutTitle)

NewPres.SaveAs ("MyPresentation.pptx")
NewPres.Close

MyPPt.Quit

MsgBox ("Presentation saved")
End Sub

Disfruta 🙂

Ventajas de Excel VBA PowerPoint

  • Usar VBA en Powerpoint hace que sea fácil de manejar si un archivo ppt tiene tantas diapositivas con contenido enorme.
  • VBA con Powerpoint da un toque de automatización incluso con funciones limitadas disponibles.

Contras de Excel VBA PowerPoint

  • Necesitamos seleccionar la Biblioteca de objetos de Microsoft PowerPoint 15.0 de la opción Referencia ubicada en la opción del menú Herramienta, que necesitamos al inicio de ejemplo-1, cada vez que ejecutamos el código de PowerPoint.

Cosas para recordar

  • Guarde el archivo en el formato de presentación habilitada para macros después de escribir el código. Esto nos ayudará a evitar perder el código y utilizar el mismo varias veces en el futuro.
  • La función de grabación no funcionará aquí ya que necesitamos saltar de Excel a PowerPoint cambiando la interfaz entre las páginas.
  • Compile siempre el código antes de ejecutarlo. Esto le ayudará a encontrar el error en el código. Esto es bastante útil cuando escribimos grandes líneas de código.
  • Para ejecutar e implementar el código necesitamos abrir la hoja de Excel con el gráfico que queremos pegar en la diapositiva de PowerPoint.
  • Podemos alinear el gráfico en PowerPoint según nuestras necesidades.

Jengibre 2.7.53.0

Jengibre 2.7.53.0

Ginger es un corrector ortográfico y gramatical gratuito.

Bloques

Bloques

Blocks es un juego intelectual para que los alumnos de 3º de primaria practiquen sus habilidades de detección y visión y está incluido por los profesores en el programa de apoyo a la enseñanza de TI.

Prezi 6.26

Prezi 6.26

Prezi es una aplicación gratuita que te permite crear presentaciones digitales, tanto online como offline.

Matemáticas

Matemáticas

Mathway es una aplicación muy útil que puede ayudarte a resolver todos aquellos problemas matemáticos que requieren una herramienta más compleja que la calculadora integrada en tu dispositivo.

Presentador de Adobe

Presentador de Adobe

Adobe Presenter es un software de aprendizaje electrónico lanzado por Adobe Systems y disponible en la plataforma Microsoft Windows como un complemento de Microsoft PowerPoint.

Tucán 2.3.0

Tucán 2.3.0

Toucan es una plataforma tecnológica educativa. Le permite aprender un nuevo idioma mientras navega por sitios web comunes y cotidianos.

ESetViet 24.2

ESetViet 24.2

eNetViet es una aplicación que ayuda a conectar a los padres con la escuela donde estudian sus hijos para que puedan comprender claramente la situación de aprendizaje actual de sus hijos.

Duolingo

Duolingo

Duolingo - Aprende Idiomas Gratis, o simplemente Duolingo, es un programa educativo que te permite aprender y practicar muchos idiomas diferentes.

Escritura rápida

Escritura rápida

RapidTyping es una herramienta de entrenamiento de teclado conveniente y fácil de usar que lo ayudará a mejorar su velocidad de escritura y reducir los errores ortográficos. Con lecciones organizadas para muchos niveles diferentes, RapidTyping le enseñará cómo escribir o mejorar sus habilidades existentes.

Matemáticas 7.4.10.53

Matemáticas 7.4.10.53

MathType es un software de ecuaciones interactivas del desarrollador Design Science (Dessci), que le permite crear y anotar notaciones matemáticas para procesamiento de textos, presentaciones, aprendizaje electrónico, etc. Este editor también se utiliza para crear documentos TeX, LaTeX y MathML.