📘 Excel逆引き事典

【VBA】全てのシートを部分一致でPDF保存する方法

日々の業務で大量のデータを扱う際、特定のキーワードを持つシートだけを選んでPDF化したいことはありませんか?手作業では時間がかかりますが、この記事のVBAマクロを使えば一瞬で完了します。ぜひお試しください。

サンプルコード

VBA
Option Explicit
Sub ExportSheetsAsPDF()
    Dim ws As Worksheet, lastRow As Long, i As Integer
    Dim pdfPath As String, sheetNamePattern As String
    
    ' PDF保存先のパスを指定
    pdfPath = "C:\Users\YourUsername\Documents\"
    
    ' 部分一致する文字列を指定
    sheetNamePattern = "Sales_2023"
    
    Application.ScreenUpdating = False
    For Each ws In ThisWorkbook.Sheets
        If InStr(ws.Name, sheetNamePattern) > 0 Then
            ws.ExportAsFixedFormat Type:=xlTypePDF, Filename:=pdfPath & ws.Name & "_" & Format(Now(), "yyyy-mm-dd_hhmmss") & ".pdf"
        End If
    Next ws
    Application.ScreenUpdating = True
End Sub

よくある質問

Q 元に戻せますか?

A.
VBAの実行結果は「元に戻す」が効きません。必ずバックアップを取ってから実行してください。

Q エラーが出たら?

A.
シート名や列番号が正しいか確認してください。