Excelを使っていて作業が終わったら、上書き保存ボタンを押してファイルを閉じるのが面倒だと思ったことありませんか?
たった1クリック1秒でできたら作業効率がアップして楽になる方法を、ここではユーザーフォームに配置した「コマンドボタン」にVBAコードを記述して使用する方法をご紹介いたします。
上書き保存をして閉じるVBA
Closeオブジェクト
エクセルに標準機能として用意されているVBA「Closeオブジェクト」は、上書き保存してエクセルを閉じる例として、よく書籍やネットに掲載されている方法です。
下記はコマンドボタン1に上書き保存するVBAコードを記述しています。
Private Sub CommandButton1_Click()
ThisWorkbook.Close SaveChanges:=True
End Sub
- コマンドボタン1がクリックされたら
- エクセルファイルを閉じる時に変更を保存する
- マクロ記録終了

ThisWorkBookがいいのかActiveWorkBookのどちらがいいのかは分かりませんが、試した結果は一緒だったので気にしていません。
この方法だと、ワークシートだけしか閉じられずエクセル自体は開いたままになってしまうので、エクセルファイルを手動で閉じる手間があるので、1クリックでできずに使い物になりませんでした。
Quitオブジェクト
エクセルに標準機能として用意されているVBA「Quitオブジェクト」は、開いているエクセルファイルが変更されている時には、変更を保存するかどうかを確認するメッセージが表示されると掲載されている方法です。
下記はコマンドボタン1に上書き保存するVBAコードを記述しています。
Private Sub CommandButton1_Click()
Application.Quit
End Sub
- コマンドボタン1がクリックされたら
- 変更を保存するかどうかを確認するメッセージを表示する
- マクロ記録終了
もちろんこれも、先ほどのCloseオブジェクトと同じくワークシート上にコマンドボタンを配置した時に、マクロを登録するためのVBAコードです。
そして、変更がある場合には下記のようにメッセージが表示されますので保存してエクセルファイルを閉じるか、保存しないかを選択できます。


エクセルファイルを閉じる方法は2つありますが、Closeオブジェクトでは完全にエクセルと閉じられず、Quitオブジェクトでは、いちいち上書き保存を聞かれ、作業効率化にならないので意味がありませんでした。
QuitとCloseの合わせ技
エクセルファイルを閉じるCloseオブジェクトとQuitオブジェクトなのに、一長一短で使うのあきらめましたが、一緒に使ったらどうなるか試してみると・・・



結果成功!
このVBAコードで、コマンドボタン1クリックで上書き保存してエクセル自体を閉じることができました。
Private Sub CommandButton1_Click()
Application.Quit
ThisWorkbook.Close savechanges:=True
End Sub
- コマンドボタン1がクリックされたら
- 変更を保存するかどうかを確認するメッセージを表示する
- エクセルファイルを閉じる時に変更を保存する
- マクロ記録終了
このようにVBAコードを記述すると、なぜか上書き保存をするかどうかの確認メッセージが表示されずに、自動的に上書き保存されてエクセルファイルが閉じられるようになりました。



正直、これができたからといっても僅かながらの手間の省力化と時短効果にしかなりませんが、できたことに満足ですけどね。
上書き保存のアレンジVBA
「上書き保存」するVBAコードを記述したコマンドボタンを誤ってクリックしたとしても、上書き保存されてファイルが閉じられるだけなので問題はないと思います。
もし、念のため「はい」「いいえ」を選択できるようにしたいならば、「Quitオブジェクト」だけを使えばいいのです。
入力済みデータ消去して上書き保存終了
ここでは入力済みセルの一部データクリアしてから上書き保存できるようにアレンジしてみました。
Private Sub CommandButton1_Click()
Msg = MsgBox(“抽選データ消去してから上書き保存しますか?”, Buttons:=vbYesNo + vbQuestion)
If Msg = vbYes Then
Sheets(“抽選”).Range(“A3:A10,B3:B10,C3:C10”).ClearContents
Application.Quit
ThisWorkbook.Close savechanges:=True
End If
End Sub
- コマンドボタン1をクリックしたら
- メッセージを表示して「抽選データ消去してから上書き保存しますか?」を「はい」「いいえ」で選択させます。
- もし「はい」を選んだら
- シート名「抽選」のセルA3~A10とB3~B10とC3~C10の各範囲の値を消す(クリア)
- 上書き保存をする
- エクセルファイルを閉じる
- IFステートメント終了
- マクロ記述終了
ちょっと長くなりましたが、簡単にいうと、「はい」を選択したら不要データクリアして上書き保存してファイルを閉じる、「いいえ」を選択したら、何もしないで元に戻るという事です。



データクリアのVBAコードを追加記述する前は、わざわざ手作業でデータクリアをしていた手間がを省くことができたので、かなりの作業効率化ができました。


よく見られているページ
-
エクセルの計算式の値を数字として読み取るVALUE関数
-
VBAの画面のちらつきがたった1行で解決して処理高速化する方法
-
COUNT関数を使って参加人数を自動的に数えるエクセル関数使用法
-
エクセルの時刻表示を0:00ではなく24:00にする方法
-
チェックボックスでチェック有と無しそれぞれの処理を変える方法
-
1クリックで上書き保存してエクセルファイルを閉じる方法
-
エクセル計算式が#VALUE!エラーになったセルを空欄にする方法
-
条件に一致したセルを繰り返し探してVBAで文字色を変える方法
-
コマンドボタンの色をクリックするたびに黒色と赤色を入れ替える方法
-
エクセルシートの保護したらマクロエラーになった時のVBA対処法


新着ページ