📘 Excel逆引き事典

【VBA】全てのシートをエラー処理付きでPDF保存する方法

手作業で各シートをPDFに変換するのは時間がかかります。この記事では、VBAを使って簡単に全てのシートをエラー処理付きでPDF保存する方法を紹介します。

サンプルコード

VBA
Option Explicit
Sub SaveAllSheetsAsPDF()
    Dim ws As Worksheet
    Dim pdfPath As String
    Dim sheetName As String
    
    ' ファイルパスの初期化
    pdfPath = "C:\Users\User\Desktop\"
    
    Application.ScreenUpdating = False
    For Each ws In ThisWorkbook.Worksheets
        On Error GoTo ErrorHandler
        sheetName = ws.Name
        ws.ExportAsFixedFormat Type:=xlTypePDF, Filename:=pdfPath & sheetName & ".pdf", Quality:=xlQualityStandard, IncludeDocProperties:=True, IgnorePrintAreas:=False, OpenAfterPublish:=False
        On Error GoTo 0 ' エラー処理終了
    Next ws
    Application.ScreenUpdating = True
    MsgBox "全てのシートをPDFとして保存しました。", vbInformation
    Exit Sub
ErrorHandler:
    MsgBox "エラーが発生しました: " & Err.Description, vbCritical
End Sub

よくある質問

Q 元に戻せますか?

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

Q エラーが出たら?

A.
シート名や列番号が正しいか確認してください。また、ワークブックが開いていることを確認してください。