vbaのアドインを作成する


はじめに

VBAについて調べてみると、作成から適用までの簡単なサンプルを交えた手順がなかなか見つからなかったため、VBAで作業効率化をしたときにアドイン化する手順をまとめます。
正直VBAのサンプルは難しいのが多いので、最も簡単なサンプルで作成してみました。

手順一覧

  1. エクセルでVBA開発を有効にする。
  2. マクロの記録をして、作成したいVBAのたたき台を作成する。
  3. 記録したマクロを改造する。
  4. 改造したマクロをテストする。
  5. アドインとして保存する。
  6. リボンとして登録する。

手順詳細

1.エクセルでVBA開発を有効にする。

タブのファイルを選択して一番左下あたりにあるオプションを選択します。


リボンのユーザー設定タブを選択して開発タブのチェックを入れます。

2.マクロの記録をして、作成したいVBAのたたき台を作成する。

タブの開発が増えているため、開発タブを選択してマクロの記録を選択します。

ウィンドウが出ますがそのままで良いです。

作成したいVBAの動きを実際にする。

エクセルの画面を使用して普通にVBAの踏み台となる動作をしてください。今回は、セルの結合をしました。

マクロの記録を終了する。

3.記録したマクロを改造する。

リボンのVisualBasicを選択する。
標準モジュールを開いてModule1を選択します。

実際にマクロを改造します。
Module1を選択して出てきた画面に2.で出たウィンドウのマクロ名と同じ名前(デフォルトはMacro1)で既にVBAが作成されていますので、それを改造していきます。
今回は、セルの結合でやったため次のようなVBAが作成されています。

Sub Macro1()
    Range("A1:B1").Select
    With Selection
        .HorizontalAlignment = xlCenter
        .VerticalAlignment = xlCenter
        .WrapText = False
        .Orientation = 0
        .AddIndent = False
        .IndentLevel = 0
        .ShrinkToFit = False
        .ReadingOrder = xlContext
        .MergeCells = False
    End With
    Selection.Merge
End Sub

この状態ではRangeで囲まれたA1~B1までしか結合できないため、クリックしたセルを結合できるようにします。

Sub Macro1()
    With Selection
        .HorizontalAlignment = xlCenter
        .VerticalAlignment = xlCenter
        .WrapText = False
        .Orientation = 0
        .AddIndent = False
        .IndentLevel = 0
        .ShrinkToFit = False
        .ReadingOrder = xlContext
        .MergeCells = False
    End With
    Selection.Merge
End Sub

セルを複数選択してから上のマクロを実行してみてください。結合できるはずです。
Range("A1:B1").Selectを消すだけでできました。
このままでは普通に用意されているセルの結合と変わらないため、もう少し改造します。
次は、セルの結合後に中央そろえにならないようにしてみます。

Sub Macro1()
    With Selection
        .VerticalAlignment = xlCenter
        .WrapText = False
        .Orientation = 0
        .AddIndent = False
        .IndentLevel = 0
        .ShrinkToFit = False
        .ReadingOrder = xlContext
        .MergeCells = False
    End With
    Selection.Merge
End Sub

セルを複数選択してから上のマクロを実行してみてください。結合後の文字が左揃えでできるはずです。
.HorizontalAlignment = xlCenterを消すだけでできました。
次にセルの色を変えてみます。

Sub Macro1()
    With Selection
        .VerticalAlignment = xlCenter
        .WrapText = False
        .Orientation = 0
        .AddIndent = False
        .IndentLevel = 0
        .ShrinkToFit = False
        .ReadingOrder = xlContext
        .MergeCells = False
        .Interior.Color = RGB(0, 176, 233)
    End With
    Selection.Merge
End Sub

セルを複数選択してから上のマクロを実行してみてください。結合後のセルが色付きで結合されました。
.Interior.Color = RGB(0, 176, 233)を追加するだけでできました。

このように自動的に作成されたVBAを改造するだけでも色々なことができます。

自動的に作成されたVBAでもたまに非効率的なことをしているため、慣れてきたらそれぞれの意味を調べてみてください。上の例でいうと.MergeCellsTrueにするとSelection.Mergeが不要になるなどです。

4.改造したマクロをテストする。

上でも実行してみてくださいと記載していましたが、基本的に作成できたらテストをしてください。
テスト方法はリボンの実行ボダンを押すだけです。
デバックが必要ならブレイクポイントもはれます。

5.アドインとして保存する。

アドインとして保存するときは、Ctr + sでファイル保存のウィンドウを開いて、ファイルの種類をExcelアドインにして保存するだけです。

他の人に共有するときはこのファイルを他のPCの同ディレクトリに格納するだけで共有できます。

6.リボンとして登録する。

保存したアドインを有効にする

このままでは、VBAを使えないため、アドインを有効にします。
新しくエクセルを開いて、1.エクセルでVBA開発を有効にする。と手順でオプションを開いてください。

アドインタブを選択して、アクティブでないアプリケーションアドインの先ほど保存したアドイン名を確認してください。

下の設定ボタンを押すとアクティブにするアドインを選択できるので、保存したアドイン名を選択してOKを押してください。

保存したアドインをリボンに設定する。

次は利用しやすいように、リボンに登録します。

1.エクセルでVBA開発を有効にする。と手順でリボンのユーザー設定タブを開いてください。

右のリボンのユーザ設定のメインタブ内のVBAを紐づけたいタブを選択して新しいグループを選択してください。

コマンドの選択でマクロを選択して、作成したVBAを選択して追加してください。

これでリボンに追加されているはずなので実際に押して試してください。

おわりに

今回はVBAについて記載しました。
仕様書の形式が多様化してきていますが、まだまだエクセルの仕様書を書くことが多いと思います。そのため、容易にエクセルの操作を自動化できるVBAがサクッと作れたら単純な作業から解放されます。個人的にはVBAは作業効率化の手段として割り切っているため短時間でできる自動化しか目指していませんが、人によってはがっつり時間をかけて全自動化しているのかもしれません。