Seguro en más de una ocasión se ha presentado la necesidad de guardar la Hoja de Excel en formato PDF, pues es precisamente lo que vamos a realizar en el siguiente ejercicio.
Macro para exportar datos de una hoja de Excel a Pdf.
Método ExportAsFixedFormat: Con la aplicación de este es posible exportar la Hoja de Excel a un archivo en formato PDF o XPS.
Para el siguiente ejemplo, vamos a trabajar con la misma tabla sencilla de la entrega anterior:
El objetivo es guardar esta hoja en un archivo PDF y lo primero es ingresar al editor de Visual Basic, puede ser con la combinación de teclas Alt + F11 y desde el explorador de proyectos, es necesario dar doble clic sobre la hoja donde se requiere crear la macro que para nuestro ejercicio se ubicará en la Hoja1:
Excel a PDF.
Aquí el código para exportar datos en Excel en formato Pdf.
Sub ExportarPDF()
ActiveSheet.ExportAsFixedFormat Type:=xlTypePDF, _
Filename:=ThisWorkbook.Path & "\Gerencie.pdf", Quality:=xlQualityStandard, _
IncludeDocProperties:=True, IgnorePrintAreas:=False, OpenAfterPublish:=True
End Sub
Queda de la siguiente manera en el editor VBA:
Veamos lo que significan cada una de las líneas:
- La primera línea Sub ExportarPDF(), indica el inicio de la macro.
- Las siguientes líneas excepto la última en realidad es una sola línea de código dividida en 3 partes para que pudiera ser visible en la imagen (obsérvese que al final de cada línea se encuentra un guion bajo con el cual se puede separar una línea de código en varias partes y que sea demasiado larga para nuestro gusto). Lo que se hace es utilizar del Objeto ActiveSheet el Método ExportAsFixedFormat e indicando el tipo que sea PDF con el parámetro Type:=xlTypePDF. Luego se especifica la ruta para guardar y el nombre que en este ejemplo será “Gerencie.pdf” y finalmente se asigna el valor Falso a las características de Propiedades y área de impresión; la última propiedad OpenAfterPublish se encuentra en True, lo que significa que una vez se genere el PDF, lo abra
- La última línea marca el fin (End) de la Macro o Subrutina (Sub).
Para ejecutar la macro, lo ideal es insertar una autoforma en la Hoja1 y luego asignar la macro que acabamos de crear (clic derecho sobre la Autoforma y seleccionar la opción Asignar macro:
Finalmente seleccionar la macro que se acaba de crear:
Y al dar clic sobre el la autoforma, la macro genera el archivo PDF en la ruta donde tenemos el archivo Excel:
Así como también deja abierto el mismo archivo para ser revisado:
julio 17th, 2019 a las 7:41 pm
Gracias, infinitas por su ayuda…saludos
mayo 6th, 2020 a las 12:03 pm
Me he bajado el archivo, pero no me da error al intentar abrirla. Tengo el Excel en mac. No se si esto tiene que ver?!
Gracias
enero 11th, 2021 a las 1:27 pm
Excelente solución!. Muchas Gracias
marzo 1st, 2021 a las 10:06 am
Si ya se creó el archivo y se ejecuta macro nuevamente, que código se coloca para que indique que el archivo ya existe en la carpeta respectiva? O bien que indique que está y si se desea reemplazar. Gracias.
octubre 22nd, 2021 a las 11:13 am
Hoja FSG , en tu mismo código tendrías que agregar el msgbox “El archivo se ha creado exitosamente!!” etc. y Listo.
noviembre 21st, 2021 a las 10:01 pm
Hola, Cómo puedo poner en el código la opción para que se pueda cambiar el nombre del archivo PDF cada vez que guardo algo?
noviembre 21st, 2021 a las 10:02 pm
…para que no se reemplace el archivo en la carpeta de destino
marzo 3rd, 2022 a las 1:10 pm
Buenas tardes, utilizo una macro para grabar una hoja en formato pdf practicamente como lo muestran aqui. (perfecto); solo que tengo el problema de que el pdf generado necesito firmarlo con una tableta para incrustar la firma. Pero el archivo (sospecho que en su configuración) no me permite hacerlo, y solo es cuando lo genero desde una macro o bien si lo creo manualmente por medio de una impresión. pero si grabo el pdf utilizando el “Guardarlo como PDF” de forma manual, si me lo permite. Habrá algun parametro que falte especificar para que me permita incrustar la firma a la hora de grabarlo?
octubre 11th, 2022 a las 8:24 pm
Hola , vengo a consultar sobre una característica especial para la macro. Resulta que cuando la ejecuto me guarda 4 páginas de PDF, en lugar de solamente una con la selección de celdas que yo quiero guardar, quisiera saber si me pueden ayudar a saber como seleccionar un rango de celdas en lugar de la hoja completa.
Muchísimas gracias por el artículo.
marzo 22nd, 2023 a las 3:16 pm
Hola muy buenas tardes,
Excelente Tutorial, yo tengo un macro diferente y me ha funcionado muy bien, la situación que se me presenta es que yo tengo protegida la hoja (celdas bloqueadas para seguridad) y cuando le doy click al boton para que me genere el archivo PDF, me dice qu eno se puede hacer por las celdas bloqueadas.
Este es el codigo de la maco:
Sub guardapdf()
‘Por.DAM
uf = ActiveCell.SpecialCells(xlLastCell).Row
ru = ThisWorkbook.Path & “\”
Range(“A1:K53”).Select
Selection.ExportAsFixedFormat Type:=xlTypePDF, _
Filename:=ru & Range(“I4″) & ” – ” & Format(Range(“C11”)) & “.pdf”, _
Quality:=xlQualityStandard, IncludeDocProperties:=True, _
IgnorePrintAreas:=False, OpenAfterPublish:=False
End Sub
Cuando me dice depurar me subraya esta linea: uf = ActiveCell.SpecialCells(xlLastCell).Row
pueden ayudarme con esta situación? que guarde pdf aún con la hoja protegida?
Altamente agradecido.
mayo 30th, 2023 a las 11:22 am
Buen dia como puedo guardar en pdf pero de forma Horizontal