BeforeSaveでは、ブックを保存する処理を実行すると保存前に指定の処理を走らせることができます。上書き保存、名前を付けて保存どちらも動作します。
イベントプロシージャの作成
イベントプロシージャを用意する前段階のモジュールの選択についてはこちら。
![beforesave1](https://sunagitsune.com/wp-content/uploads/2023/10/beforesave1.png)
Workbookを選んでからBeforeSaveを選択します。
![beforesave2](https://sunagitsune.com/wp-content/uploads/2023/10/beforesave2.png)
プロシージャが作成されるので、この中に処理を記述します。
BeforeSaveの使い方
' vba
Private Sub Workbook_BeforeSave(ByVal SaveAsUI As Boolean, Cancel As Boolean)
MsgBox ("セーブします")
End Sub
とりあえず保存前にメッセージボックスを表示するようにしてみましたが、
![beforesave3](https://sunagitsune.com/wp-content/uploads/2023/10/beforesave3-500x256.png)
コードを適用するために上書き保存した段階でもう動作しました。
![beforesave4](https://sunagitsune.com/wp-content/uploads/2023/10/beforesave4.png)
普通に上書き保存した時も動作しますし、
![beforesave5](https://sunagitsune.com/wp-content/uploads/2023/10/beforesave5-500x322.png)
名前を付けて保存する時も動作します。保存場所を選んだ時点でBeforeSaveが動き、
![beforesave6](https://sunagitsune.com/wp-content/uploads/2023/10/beforesave6.png)
それからファイルに名前を付ける、という順序になるようです。
![](https://sunagitsune.com/wp-content/uploads/2018/10/gui-2311261_1280.png)
やりたいことから方法を探すエクセル(Excel)操作・関数・VBA(マクロ)逆引きまとめ
逆引き(やりたいことから探す)Excel記事まとめ
![](https://sunagitsune.com/wp-content/uploads/2018/12/mathematics-1509559_1280-160x90.jpg)
関数・演算子・メソッド・プロパティ名から探すExcel/VBA(マクロ)使い方・組み合わせ方まとめ
こちらはExcelやメソッドの諸機能を、機能の名称から探せるまとめ記事です。
コメント