教えて!ExcelVBA!

ExcelVBAの基礎知識・書き方について説明していきます。

【ExcelVBA その他操作】警告メッセージを非表示にする(Application.DisplayAlerts)にはどうすればいいの?教えて!

       f:id:m_kbou:20200418090138p:plain

データを変更した後にブックを閉じようとした場合、上書き確認の警告メッセージが表示されます。この警告メッセージを非表示にする方法があるので、そのやり方について説明します。

 

【目次】

 

構文

記述方法は、以下の通りとなります。

=======================================================================

Application.DisplayAlerts = False

Application.DisplayAlerts = True

=======================================================================

[説明]:

警告メッセージを非表示にするには「Application.DisplayAlerts = False」と記述します。また、警告メッセージを表示するようにする(元に戻す)には「Application.DisplayAlerts = True」と記述します。内容を纏めると、「警告メッセージを非表示にして下さい。又は、警告メッセージを表示するようにして下さい。」との意味になります。

 

使い方

使い方について、具体的に説明していきます。

警告メッセージを非表示にしないケース

警告メッセージを非表示にしない状態で変更したブックを閉じるケースについて説明します。

[記述例]:

※以下の記述例は、VBE(VBA記述画面)に記述しないと実行ができません。VBEの開き方については、VBEの開き方を参考にして下さい。

-------------------------------------------------

Sub サンプル()

    ActiveWorkbook.Close

End Sub

-------------------------------------------------

「現在アクティブになっているブックを閉じて下さい」との意味になります。

[実行例]:

(実行前)

※開いたブックのA1セルに”テスト”の文字を入力します。

f:id:m_kbou:20200306144232p:plain

(実行後)

※ブックを閉じようとすると警告メッセージが表示され、いずれかのボタンのクリックを要求されます。

f:id:m_kbou:20200306144247p:plain

警告メッセージを非表示にしないケースについての説明は以上です。

 

警告メッセージを非表示にするケース

警告メッセージを非表示にする指定をした状態で変更したブックを閉じるケースについて説明します。

[記述例]:

※以下の記述例は、VBE(VBA記述画面)に記述しないと実行ができません。VBEの開き方については、VBEの開き方を参考にして下さい。

-------------------------------------------------

Sub サンプル()

    Application.DisplayAlerts = False
    ActiveWorkbook.Close
    Application.ScreenUpdating = True

End Sub

-------------------------------------------------

「まず最初に警告メッセージが表示させないモードに切り替え、次に現在アクティブになっているブックを閉じてから、最後に警告メッセージが表示させるモード(元のモードに戻す)に切り替えて下さい。」との意味になります。

[実行例]:

(実行前)

※開いたブックのA1セルに”テスト”の文字を入力します。

f:id:m_kbou:20200306144232p:plain

(実行後)

※警告メッセージが表示されずにブックが閉じます。

f:id:m_kbou:20200306144644p:plain

警告メッセージを非表示にするケースについての説明は以上です。

 

おわりに

今回は警告メッセージを非表示にする方法について説明しました。警告メッセージを非表示にする指定(Application.DisplayAlerts = False)をすると、ブックを閉じる時の上書き保存の確認メッセージだけではなく、その他全てのメッセージも非表示となります。指定する場合には注意して下さい。また、メッセージを非表示にする指定をしたマクロを実行した場合、処理が終了すると同時にメッセージが表示される状態(Application.ScreenUpdating = True)に戻ります。こちらも覚えておいて下さい。