📘 Excel逆引き事典

【VBA】可視セル(フィルタ結果)を完全一致でPDF保存する方法

毎回手作業でフィルタ結果の部分のみを印刷やPDF保存するのは大変です。この記事では、Excel VBAを使用してフィルター後の可視セルだけをPDFとして保存する方法を紹介します。

サンプルコード

VBA
Option Explicit
Sub SaveFilteredRangeAsPDF()
    Dim ws As Worksheet
    Set ws = ThisWorkbook.Sheets("Sheet1") ' フィルタリングを行ったシート名に変更してください。
    
    Application.ScreenUpdating = False ' スクリーン更新を停止して高速化
    
    With ws.Range("A1:Z100") ' フィルタ結果の範囲を指定(適宜調整)
        If .SpecialCells(xlCellTypeVisible).Count > 0 Then ' 可視セルが存在する場合のみ処理
            .ExportAsFixedFormat Type:=xlTypePDF, Filename:="C:\path\to\your\file.pdf", Quality:=xlQualityStandard, IncludeDocProperties:=True, IgnorePrintAreas:=False, OpenAfterPublish:=False ' PDF保存の設定(適宜調整)
        End If
    End With
    
    Application.ScreenUpdating = True ' スクリーン更新を再開
End Sub

よくある質問

Q 元に戻せますか?

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

Q エラーが出たら?

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