0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

始めてのExcel VBA

Posted at

Excel のVBA 機能を使えるようにするための最初の設定~Hello, World! の表示までを解説

プログラムを作成するうえで大切なデバッグやエラー処理についても解説します。

ここをおさえておけば自力でプログラムを作成するとき、上手く動かないところがあっても原因箇所を調べたりすることができるようになります。

特に独学で使い始めようとして、初期設定のまま使い始めてエラーメッセージが表示されまくってしまったり、デバッグ作業で心が折れそうになることがあるので、解説の初期設定をしてもらうだけでかなり効率が良くなるはずです。

1.開発タブを表示させる

「オプション」→「リボンのユーザー設定」→「開発」にチェックを入れ、開発タブを表示します。
01.png

2.IDEの初期設定

「開発」タブを選択し、「Visual Basic」をクリックしてMicrosoft Visual Basic for Applications(以下 IDE) を表示します。

「ツール(T)」→「オプション(O)...」をクリックします。
02.png

設定する項目は、以下の通りです。
03.png

オプション
タブ 項目 説明
編集 自動構文チェック(K) OFF エラーメッセージうざいのでOFF
変数の宣言を強制する(R) ON 変数名のTypo を発見しやすくなるのでON
全般 エラー発生時に中断(B) ON エラーが発生した行で止まってくれる
順次コンパイル(P) OFF 実行前にコンパイルエラーが見つかるようOFF

3.ボタンを配置

プログラムを実行する起点となるボタンを配置します。

「開発」タブの「挿入」から「ボタン (フォームコントロール)」をクリックし、シート状でドラッグするとボタンが配置され、「マクロの登録」ダイアログが表示されます。

マクロ名にボタンがクリックされたときに呼ばれる処理の名前(ボタンHelloWorld_Click)を入力、マクロの保存先「作業中のブック」を選択して、「新規作成(N)」をクリックします。
04.png

すると、IDE 画面に標準モジュール(Module1)が追加され、画面のようなコードが生成されます。
標準モジュールのモジュール名は、分かりやすい名前(mdlMain)に変更しておきます。
05.png

4.Hello, World!

実際に、ボタンがクリックされた時の処理を記述します。

mdlMain
'スペルミスなどで間違った変数が使われるのを防止するため
'このファイル内で変数の宣言を強制します。
Option Explicit

'ボタンがクリックされるとここに記述された処理が実行されます
Sub ボタンHelloWorld_Click()
    Call MsgBox("Hello, world!", vbInformation Or vbOKOnly, "始めてのプログラム")
End Sub

06.png

5.実行

ボタンをクリックするとプログラムが実行されます。
07.png

6.デバッグ

プログラムの動作を途中で止めて確認したいときは、赤枠部分をクリックするとブレークポイントを設定することができます。
ブレークポイントをもう一度クリックするとブレークポイントが解除されます。

次の行を実行するときは「F8」キーを押すと現在の行が実行され、次の行へ移ります。
08.png

デバッグの時には、「表示(V)」→「イミディエイトウィンドウ(I)」を表示しておくと便利です。
09.png

mdlMain
'指定された値がイミディエイトウィンドウに表示される
Debug.Print "こんにちは"

10.png

7.エラーが発生したときにエラーメッセージを表示する

処理の途中で意図しないエラーが発生した時、そのまま処理が進行してしまうとデータを破壊したりする可能性があるため、処理を安全に中断する仕組みが必要です。

VBA ではエラーが発生したとき、指定したラベルに処理をジャンプさせることができます。

mdlMain
Sub ボタンエラーテスト_Click()
On Error GoTo Error:
    Dim 配列()  As Long
    '配列は、
    'Dim 配列(1)  As Long
    'のように宣言時に配列数を指定するか
    'Dim 配列()  As Long
    'の後に
    'Redim 配列(1)
    'で配列数を確保する必要がある
    
    '存在しない配列にアクセスしようとすると「9:インデックスが有効範囲にありません。」というエラーが発生する
    配列(0) = 1
    
    Debug.Print "正常終了"
Finaly:
    'ここに正常時でも異常時でも実行する処理を書ける
    Debug.Print "常に実行"
Exit Sub
Error:
    Debug.Print "エラー発生"
    'エラーが発生したときは処理の途中からここにジャンプするので、ログファイルにエラーを出力したり、エラーメッセージを表示する
    Call MsgBox("[" & Err.Number & "]" & vbCrLf & Err.Description, vbCritical Or vbOKOnly)
    GoTo Finaly
End Sub

なお、最初に設定したオプション画面で、「エラートラップ:エラー発生時に中断(B)」になっていると、エラーが発生した行で止まるためError: には処理が移りません。
動作を確認するときは、一時的に「クラス モジュールで中断(R)」に変更してください。
11.png

8.まとめ

時々、初期設定のままに使っていてデバッグで凄く苦労している人がいるので、オプション画面の設定を変更しておくのは凄くおすすめです。

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?