How to Use Excel VBA to Print to PDF with a Custom File Name?
Are you looking for a way toΒ automatically print your Excel worksheets to PDFΒ with aΒ custom file name? UsingΒ Excel VBAΒ (Visual Basic for Applications), you can create a macro that willΒ save your worksheets as PDF filesΒ withΒ dynamic names based on cell values. In this article, weβll walk through step-by-step how to set up a VBA macro toΒ print to PDFΒ and specify theΒ PDF file name.
Why Use Excel VBA to Print to PDF?
There are several compelling reasons to leverageΒ Excel VBA for printing to PDF:
- AutomationΒ β You can automate the process of saving worksheets as PDFs, saving significant time and effort compared to manually printing each one. This is especially advantageous when you have a large number of sheets that need to be saved as individual PDF files.
- Custom File NamesΒ β By using VBA, you can dynamically generate PDF file names based on worksheet content like cell values, the worksheet name, or the current date. This is much more flexible than using Excelβs built-in βSave As PDFβ feature, which doesnβt allow for customized naming conventions.
- Batch ProcessingΒ β A VBA macro can loop through all the worksheets in your workbook and save each one to a separate PDF, allowing you to print multiple sheets at once. This batch processing capability is a huge efficiency booster when dealing with sizeable workbooks.
- No Printing DialogΒ β When you print to PDF using VBA, the printing dialog box doesnβt appear, making the process seamless and free from manual intervention. The macro can run in the background without disrupting your other work.
- ConsistencyΒ β Using a macro ensures that your PDFs are generated consistently each time, with the same settings, formatting, and naming scheme. This standardization can be difficult to achieve with manual printing.
So letβs look at how to actually implementΒ printing to PDF with custom file names using VBA in Excel.
Step 1: Enable the Developer Tab in Excel
To create anΒ Excel VBA macro, you first need to enable theΒ Developer tabΒ in the ribbon if itβs not already visible. Hereβs how:
- Go toΒ File > Options
- Click onΒ Customize Ribbon
- UnderΒ Main Tabs, check the box next toΒ Developer
- ClickΒ OKΒ to close the Excel Options dialog
You should now see theΒ Developer tabΒ appear in the ribbon. This tab contains tools for working with macros and other advanced Excel features.
Step 2: Open the Visual Basic Editor
With the Developer tab enabled, you can now open theΒ Visual Basic EditorΒ to start writing your macro:
- Go to theΒ Developer tab
- Click theΒ Visual BasicΒ button (or pressΒ Alt+F11)
The Visual Basic Editor will open in a new window. This is the integrated development environment (IDE) where youβll write theΒ VBA code for your print to PDF macro.
Step 3: Create a New Module
In theΒ Visual Basic Editor, you need to insert a new module to hold your macro code:
- In theΒ ProjectΒ pane on the left, find your workbook
- Right-click on the workbook and selectΒ Insert > Module
A new module will be created where you can type yourΒ print to PDF VBA code. Modules are containers for related pieces of code, and help keep your project organized.
Step 4: Write the Print to PDF Macro Code
Now youβre ready to write the actualΒ VBA macro to print your worksheet to a PDF. Hereβs the code to use:
Sub PrintWorksheetToPDF() 
    Dim wsA As Worksheet
    Dim wbA As Workbook
    Dim strTime As String
    Dim strName As String
    Dim strPath As String
    Dim strFile As String 
    Dim strPathFile As String
    Dim myFile As Variant
    Set wbA = ActiveWorkbook
    Set wsA = ActiveSheet
    strTime = Format(Now(), "yyyymmdd\_hhmm")
    'Get the name from cell A1
    strName = wsA.Range("A1").Value
    'Target folder, use current workbook folder as default
    strPath = wbA.Path
    If strPath = "" Then
        strPath = Application.DefaultFilePath 
    End If
    strPath = strPath & "\"
    'Create PDF file name
    strFile = strName & "_" & strTime & ".pdf"
    strPathFile = strPath & strFile
    myFile = Application.GetSaveAsFilename _
        (InitialFileName:=strPathFile, _
            FileFilter:="PDF Files (*.pdf), *.pdf", _ 
                    Title:="Select Folder and FileName to save")
    If myFile <> "False" Then
        wsA.ExportAsFixedFormat _
            Type:=xlTypePDF, _
            Filename:=myFile, _
            Quality:=xlQualityStandard, _
            IncludeDocProperties:=True, _ 
            IgnorePrintAreas:=False, _
            OpenAfterPublish:=False
        'confirmation message 
        MsgBox "Your PDF file has been created: " _
            & vbCrLf _
            & myFile
    End If
End Sub
Hereβs a breakdown of what this code does:
- Declares variablesΒ to hold the active workbook, worksheet, PDF file path, and file name. Using clear variable names makes the code more readable.
- Gets the current date and timeΒ to use in the file name. This is done using the VBAΒ FormatΒ andΒNowΒ functions.
- Retrieves a name value from cell A1Β in the active worksheet. You can change this cell reference to pull the name from elsewhere.
- Sets the target folderΒ to the current workbookβs folder. If the workbook isnβt saved, it uses the applicationβs default file path.
- Creates the PDF file nameΒ by combining the name from A1, a date/time stamp, and the β.pdfβ extension.
- Prompts the user to select a folder and file nameΒ to save the PDF using theΒ GetSaveAsFilenameΒ method. This displays a standard βSave Asβ dialog box.
- Exports the active worksheet as a PDFΒ using the specified file path and name. TheΒ ExportAsFixedFormatΒ method is used for this.
- Displays a message boxΒ confirming the PDF was created, showing the full file path.
You can modify parts of this code, such as theΒ location it pulls the PDF file name fromΒ (currently cell A1) orΒ additional details to include in the file name.
Step 5: Run the Print to PDF Macro
To run your new macro andΒ print your active worksheet to a PDF:
- Go back to theΒ Excel workbook
- Make sure the worksheet you want to print to PDF is active
- Go to theΒ Developer tab
- ClickΒ Macros
- Select yourΒ PrintWorksheetToPDFΒ macro and clickΒ Run
The macro will run, prompting you to select a location and file name to save the PDF. After saving, a message box will confirm the PDF file creation.
Alternatively, you can run the macro directly from theΒ Visual Basic EditorΒ by clicking the green βplayβ button or pressingΒ F5.
And thatβs it! Youβve now created anΒ Excel VBA macro to automatically print your worksheet to a PDF with a custom file name. This technique can save you significant time and effort when you need to generate PDF versions of your Excel worksheets.
Tips for Using the Print to PDF Excel Macro
Here are a few suggestions to get the most out of thisΒ print to PDF automation:
- Customize the cell referenceΒ where the macro pulls the PDF name from based on your worksheet layout. You can use any cell or combination of cells to build the file name.
- Modify the name formatΒ to include other useful details like the workbook name, worksheet name, date, username, etc. This can make it easier to keep track of your generated PDFs later.
- Use the macro in combination withΒ other VBA code to loop through multiple worksheetsΒ in your workbook andΒ save each to its own PDF. This is a big time-saver if you need to print every worksheet at once.
- Add error handlingΒ to your macro code to gracefully handle issues like invalid sheet names, write-protected destination folders, etc. This will make your macro more robust and reliable.
- ConsiderΒ adding a button to run the macroΒ so you donβt need to open the Developer tab each time. You can insert a button and assign the macro to run when clicked.
- If you frequently use this macro,Β save it in your Personal Macro WorkbookΒ so itβs available in all your Excel files. This saves you from recreating it in each workbook.
Advanced Techniques
Once youβve mastered the basics ofΒ printing to PDF with VBA, there are many ways to extend the technique, such as:
- Automatically emailing the generated PDFΒ using VBA code to open a new email message, attach the PDF, and send it to a specified recipient
- Saving PDFs to a SharePoint document libraryΒ or other cloud location by mapping a network drive with VBA and using that as the destination folder
- Encrypting and password-protecting the PDFsΒ for added security using theΒ ExportAsFixedFormatΒ method parameters
- Merging multiple worksheets into a single PDFΒ by exporting each sheet to a temporary PDF file and then using a PDF library to combine them into one document
The possibilities are nearly endless once you understand the core concepts ofΒ programmatically exporting Excel sheets to PDF format with VBA.
Final Thoughts
Printing your Excel worksheets to PDF with custom file namesΒ is easy with aΒ VBA macro. The code provided here willΒ prompt you for a save location,Β pull a name value from cell A1,Β combine it with a date/time stamp, andΒ save the active sheet as a PDF.
With a few tweaks, you can adapt this technique toΒ automatically generate PDF versions of your Excel sheetsΒ just the way you need. You can batch print multiple sheets, create standardized naming conventions, email the PDFs, and much more.
Implementing anΒ Excel print to PDF macroΒ is a great way toΒ automate repetitive tasks, ensureΒ consistency, andΒ save significant time and effort. Give it a try and see how it can streamline your workflows! Let me know if you have any other questions.
FAQs
What is Excel VBA?
Why would I want to print an Excel file to PDF with a custom file name?
What are the prerequisites for using Excel VBA to print to PDF?
How do I create a macro in Excel to print to PDF with a custom file name?
Can I specify the location where the PDF file is saved using Excel VBA?

Vaishvi Desai is the founder of Excelsamurai and a passionate Excel enthusiast with years of experience in data analysis and spreadsheet management. With a mission to help others harness the power of Excel, Vaishvi shares her expertise through concise, easy-to-follow tutorials on shortcuts, formulas, Pivot Tables, and VBA.
