教えて!ExcelVBA!

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

【ExcelVBA ブック操作】ブック内のシートが変更された時に発生するイベントプロシージャを作成するにはどうすればいいの?教えて!

f:id:m_kbou:20200520100227p:plain

VBAでは操作をきっかけとして自動的に実行されるプロシージャの事を「イベントプロシージャ」と言います。自動実行のきっかけとなる操作の事を「イベント」と呼び、「イベント」はブックやワークシート、ユーザーフォーム等のオブジェクトに対して発生します。このイベントを利用して「ブック内のシートが変更された時に発生するイベントプロシージャの作り方」について紹介します。

 

 

構文

イベントプロシージャの記述方法は以下の通りです。

Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range)
  [実行する処理内容]
End Sub

[説明]:

ブック内のシートが変更された時に発生するイベントプロシージャにはSheetChangeプロシージャを使用します。[実行する処理内容]にはブック内のシートが変更された際に実行させる内容を記述します。ShとTargetは引数となり、shは変更されたシートのオブジェクト、Targetは入力値が変更されたセルとなります。内容を纏めると、「ブック内のシートが変更された時に[実行する処理組内容]を実行して下さい。」との意味になります。

[記述例]:

Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range)
  MsgBox "内容が変更されました。"
End Sub

 

作り方

(1)VBE(VBA記述画面)を開きます。

※画面の開き方はこちらの手順を参考にして下さい。

f:id:m_kbou:20200515084943p:plain

(2)ブックオブジェクトをダブルクリックします。

f:id:m_kbou:20200515085021p:plain

(3)オブジェクトボックスの▼ボタンをクリックします。

f:id:m_kbou:20200515085036p:plain

(4)プルダウン一覧の中から「WorkBook」を選択します。

f:id:m_kbou:20200515085050p:plain

(5)この時点で「Workbook_Open」イベントプロシージャが表示されます。(これは自動的に作成される仕組みとなっている様です。)

f:id:m_kbou:20200506112910p:plain

(6)プロシージャボックスの▼ボタンをクリックします。

f:id:m_kbou:20200515085137p:plain

(7)プルダウン一覧の中から「SheetChange」を選択します。

f:id:m_kbou:20200520100435p:plain

(8)「Workbook_SheetChange」イベントプロシージャが表示されます。

f:id:m_kbou:20200520100523p:plain

(9)(8)で作成したイベントプロシージャに実行させる内容を記述します。以下で記述例を3つ紹介します。

(例①)ブック内のシートが変更された時にメッセージを表示する方法

ブック内のシートが変更された時にメッセージを表示する方法について紹介します。

[プログラミング例①]:

Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range)
  MsgBox "内容が変更されました。"
End Sub

内容は、「ブック内のシートを変更された時に”内容が変更されました。”をMsgBoxで表示して下さい。」との意味になります。

f:id:m_kbou:20210619165848p:plain

[実行例①]:

今回の例としては、Book1.xlsmブックには上記で説明したイベントプロシージャが記述されています。

(実行前)

Book1.xlsmブックのSheet1シート内のA1セルに数値:1がセットされています。

f:id:m_kbou:20210619165905p:plain

(実行後) 

A1セルの数値を1→2へ変更すると同時に「内容が変更されました。」が表示されます。(Book1.xlsmブックのSheet1シート内のA1セルの値が変更された事で、プロシージャが実行されてメッセージが表示されました。)

f:id:m_kbou:20210619165919p:plain

[サンプル①]: 

上記で説明したファイルをダウンロードできます。ご自由にお使い下さい。

drive.google.com

(例②)ブック内のシートが変更された時に変更されたシート名を表示する方法

ブック内のシートが変更された時に変更されたシート名を表示する方法について紹介します。

[プログラミング例②]:

Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range)
  MsgBox Sh.Name
End Sub

内容は、「ブック内の変更されたシート名をMsgBoxで表示して下さい。」との意味になります。

f:id:m_kbou:20210619171507p:plain

[実行例②]:

今回の例としては、Book1.xlsmブックが開かれており、Book1.xlsmブックには上記で説明したプログラミング例②が記述されています。

(実行前)

Book1.xlsmブックのSheet1シート内のA1セルに数値:1がセットされています。

f:id:m_kbou:20210619170647p:plain

(実行後) 

A1セルの数値を1→2へ変更すると同時にシート名「Sheet1」が表示されます。(Book1.xlsmブックのSheet1シート内のA1セルの値が変更された事で、プロシージャが実行されてメッセージが表示されました。)

f:id:m_kbou:20210619170701p:plain

[サンプル②]:

上記で説明したファイルをダウンロードできます。ご自由にお使い下さい。

drive.google.com

(例③)ブック内シートのセル値が変更された時に変更したされたセルのアドレスを表示する方法

ブック内シートのセル値が変更された時に変更されたセルのアドレスを表示する方法について紹介します。

[プログラミング例③]:

Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range)
  MsgBox Target.Address
End Sub

内容は、「ブック内シートのセル値が変更された時に変更されたセルのアドレスを表示して下さい。」との意味になります。

f:id:m_kbou:20210619171223p:plain

[実行例③]:

今回の例としては、Book1.xlsmブックが開かれており、Book1.xlsmブックには上記で説明したプログラミング例③が記述されています。

(実行前)

Book1.xlsmブックのSheet1シート内のA1セルに数値:1がセットされています。

f:id:m_kbou:20210619171239p:plain

(実行後) 

A1セルの数値を1→2へ変更すると同時にセルのアドレス「$A$1」が表示されます。(Book1.xlsmブックのSheet1シート内のA1セルの値が変更された事で、プロシージャが実行されてメッセージが表示されました。)

f:id:m_kbou:20210619171252p:plain

[サンプル③]:

上記で説明したファイルをダウンロードできます。ご自由にお使い下さい。

drive.google.com

ブック内のシートが変更された時に発生するイベントプロシージャの作成方法についての説明は以上です。

 

おわりに

今回はブック内のシートが変更された時に発生するイベントプロシージャの作成方法について説明しました。オブジェクトボックスでオブジェクトを選択すると、そのオブジェクト既定の「Workbook_Open」イントプロシージャが自動的に作成(上記(5)の内容)されます。不要な場合は削除して下さい。