📘 Excel逆引き事典

【VBA】データの最終行を確認メッセージを出さずにPDF保存する方法

手作業で大量のデータをPDFに変換するのは時間がかかります。この記事では、VBAを使用して自動化し、効率的に業務を進めましょう。確認メッセージが出ることなく、指定した範囲をPDFとして保存します。

サンプルコード

VBA
Option Explicit
Sub SaveToPDFWithoutAlert()
    Dim ws As Worksheet
    Set ws = ThisWorkbook.Sheets("Sheet1")
    
    ' 最終行の取得
    Dim lastRow As Long
    lastRow = ws.Cells(ws.Rows.Count, "A").End(xlUp).Row
    
    ' PDF保存の設定
    With Application
        .ScreenUpdating = False
        .DisplayAlerts = False
    End With
    
    ' データ範囲を選択してPDFに保存
    ws.Range("A1:A" & lastRow).ExportAsFixedFormat Type:=xlTypePDF, Filename:="C:\Users\User\Documents\data.pdf", Quality:=xlQualityStandard, IncludeDocProperties:=True, IgnorePrintAreas:=False, OpenAfterPublish:=False
    
    ' メモリ解放と設定の戻し
    Set ws = Nothing
    Application.ScreenUpdating = True
    Application.DisplayAlerts = True
End Sub

よくある質問

Q 元に戻せますか?

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

Q エラーが出たら?

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