Excel アドインを VBA で作成する
このページでは、Excel アドインを VBA で作成する手順を記載します。
目次
注意
- 確認した Excel のバージョンは Excel for Office 365 (16.0.11727.20222。Excel 2019 相当) です。将来のバージョンでは動作しない可能性があります。
単純な手順 (クイックツールバーに追加する)
1. VBA で関数を作成する
VBA で関数を1つ作成します。(「マクロの記録」で関数を作っても可)
data:image/s3,"s3://crabby-images/7b8d4/7b8d4c7c49d74744bb5eee8ff48dfdf81a9afbb2" alt=""
data:image/s3,"s3://crabby-images/c1c7d/c1c7d7f16af3f2210942e3ada42edd82502363cf" alt=""
Sub Test()
MsgBox "Test"
End Sub
2. 1 を xlam ファイルで保存し、一度 Excel を再起動する
C:\Users\ユーザー名\AppData\Roaming\Microsoft\AddIns
に保存data:image/s3,"s3://crabby-images/31e1e/31e1e757805121288ddf7a82d04398fef896bf2e" alt=""
※ Excel を再起動しないと 3 で項目が出てきません。
3. 「開発」タブ >「Excel アドイン」から 2 で保存したファイル名と同じものをチェック
data:image/s3,"s3://crabby-images/a198a/a198a71caae98b73242fa8ab330ddefd72cb9966" alt=""
data:image/s3,"s3://crabby-images/83255/8325544611cea15d6b5123f67c5b6908ad23f992" alt=""
4. 「クイックアクセスツールバーのユーザー設定」>「その他のコマンド」からコマンドの種類を「マクロ」にして 1 で作成したマクロを選択
data:image/s3,"s3://crabby-images/709f8/709f8440e09967fb725368ca686cea12e6bcf669" alt=""
data:image/s3,"s3://crabby-images/34a07/34a070b7c5bf278d96e4316e9659c8ed6baf465b" alt=""
結果
data:image/s3,"s3://crabby-images/36817/36817fb9a80920010e8cbe1cdb0b60df0e1a12a2" alt=""
メニューコマンドとして追加する手順
1. VBA で関数を作成する
data:image/s3,"s3://crabby-images/7b8d4/7b8d4c7c49d74744bb5eee8ff48dfdf81a9afbb2" alt=""
data:image/s3,"s3://crabby-images/b1373/b1373972b2d30bce4dff7b2109837e81b81e4893" alt=""
Const MENU_ITEM_NAME = "Test"
Private Sub Workbook_AddinInstall() ' アドインのインストール時
With Application.CommandBars("Worksheet Menu Bar") ' メニューコマンド領域
On Error Resume Next
.Controls(MENU_ITEM_NAME).Delete ' メニュー項目追加
On Error GoTo 0
With .Controls.Add(Type:=msoControlButton, before:=.Controls.Count, temporary:=True)
.Caption = MENU_ITEM_NAME ' メニュー名
.OnAction = "Test" ' 実行する関数
.Style = msoButtonIconAndCaption ' ボタンの外観 (https://docs.microsoft.com/ja-jp/office/vba/api/office.msobuttonstyle)
.FaceId = 59 ' ボタンのアイコン (https://www.microsoft.com/en-us/download/details.aspx?id=50745)
End With
End With
End Sub
Private Sub Workbook_AddinUninstall() ' アドインのアンインストール時
With Application.CommandBars("Worksheet Menu Bar")
On Error Resume Next
.Controls(MENU_ITEM_NAME).Delete ' メニュー削除
On Error GoTo 0
End With
End Sub
data:image/s3,"s3://crabby-images/71b52/71b526750713c45be062de7faa9e089320def3cc" alt=""
Sub Test()
MsgBox "Test"
End Sub
2. 1 を xlam ファイルで保存し、一度 Excel を再起動する
C:\Users\ユーザー名\AppData\Roaming\Microsoft\AddIns
に保存data:image/s3,"s3://crabby-images/f6d8d/f6d8d8c6d5818e36fdb96f14f19cd18bd96dd3ff" alt=""
※ Excel を再起動しないと 3 で項目が出てきません。
3. 「開発」タブ >「Excel アドイン」から 2 で保存したファイル名と同じものをチェック
data:image/s3,"s3://crabby-images/a198a/a198a71caae98b73242fa8ab330ddefd72cb9966" alt=""
data:image/s3,"s3://crabby-images/3f18c/3f18c0164c6ff03b3564ca4e65b8306d6d89cbef" alt=""
結果
data:image/s3,"s3://crabby-images/8f9ab/8f9ab53a0c230138b0e4f331224f5a5e7fad0041" alt=""