IT仕事

Excel2007でアドインを作って登録するまでの手順

投稿日:2012年1月17日 更新日:

Googleさまで探してもあまり好みの回答にたどり着かなかったので、自分及び誰かのためになるかと思いメモメモ。

■1.標準モジュールにアドインにしたいコードを作成する。

以下のコードは、単純に、

「セル内にある数字の先頭にシングルコーテーションを付加し、さらにハイフンを取り除く」

電話番号からハイフンを削除してキレイな数字のみにする処理です。0が消えるとイヤなのでシングルコーテーションを付けています。

Sub ハイフン削除1()
For Each c In Selection
v = "'" & c.Text
c.Value = Replace(v, "-", "")
Next
End Sub

Sub ハイフン削除2()
For Each c In Selection
v = "'" & c.Text
c.Value = Replace(v, "ー", "")
Next
End Sub

■2.VBAのThisWorksheetに以下のコードを追加する。

リボンのアドインメニューに、新しいボタンを作る/削除する、コードですね。

—-ここから—-

Public CPop As Office.CommandBarPopup
Private Sub Workbook_AddinInstall() '「Excelのオプション」で登録する際に実行されるコード
Set CPop = Application.CommandBars("Worksheet Menu Bar").Controls.Add(Type:=msoControlPopup)
With CPop
.Caption = "ハイフン削除1"
.OnAction = "ハイフン削除1"
End With
Set CPop = Application.CommandBars("Worksheet Menu Bar").Controls.Add(Type:=msoControlPopup)
With CPop
.Caption = "ハイフン削除2"
.OnAction = "ハイフン削除2"
End With
End Sub
Private Sub Workbook_AddinUninstall() '「Excelのオプション」で削除する際に実行されるコード
On Error Resume Next
Application.CommandBars("Worksheet Menu Bar").Controls("先頭番号の重複チェック").Delete
Application.CommandBars("Worksheet Menu Bar").Controls("FAXエラーチェック").Delete
End Sub

—-ここまで—-

■3.作ったら、ファイルを「ハイフン削除」アドインとして保存する(拡張子は自動的にxlamになる)。

保存する場所は変えない(C:\Users\ユーザ名\AppData\Roaming\Microsoft\AddIns\)。ネットワークに登録してもいいが、変えると次の4で呼び出すのが面倒なので、テスト中はそのままがよいかも。

■4.Excelアプリにアドインを登録する。

Officeボタンから、「Excelのオプション」「アドイン」「設定」とたどり、表示されるダイアログボックスで、先ほど保存した「ハイフン削除」アドオンが表示されるので、チェックを付けて登録する。

以下、追記:2014/6/20(金)

Excelを閉じると、アドインのメニューが消えてしまった・・・・。
以下のように、open時とclose時にも、メニューを表示する処理を入れるとOk。
(以前とメニュー内容が変わっているのは、本番のをコピペしたから)

Public CPop As Office.CommandBarPopup

Private Sub Workbook_AddinInstall() ‘「Excelのオプション」でアドオン登録する際に実行
Call MenuAdd
End Sub

Private Sub Workbook_Open() ‘Bookを開くときに実行
Call MenuAdd
End Sub

Private Sub Workbook_AddinUninstall() ‘「Excelのオプション」でアドオン削除する際に実行
Call MenuDel
End Sub

Private Sub Workbook_BeforeClose(Cancel As Boolean) ‘Bookを閉じるときに実行
Call MenuDel
End Sub

Private Sub MenuAdd()
Set CPop = Application.CommandBars(“Worksheet Menu Bar”).Controls.Add(Type:=msoControlPopup)
With CPop
.Caption = “先頭番号の重複チェック”
.OnAction = “先頭番号の重複チェック”
End With
Set CPop = Application.CommandBars(“Worksheet Menu Bar”).Controls.Add(Type:=msoControlPopup)
With CPop
.Caption = “FAXエラーチェック”
.OnAction = “FAXエラーチェック”
End With
End Sub

Private Sub MenuDel()
On Error Resume Next
Application.CommandBars(“Worksheet Menu Bar”).Controls(“先頭番号の重複チェック”).Delete
Application.CommandBars(“Worksheet Menu Bar”).Controls(“FAXエラーチェック”).Delete
End Sub

-IT仕事

執筆者:

関連記事

no image

AccessのデータをGoogleスプレッドシートに表示する

会社のネットショップで、お客様から電話で荷物の出荷状況について問い合わせがあった場合に、現状ではすぐに対応できていなかった。 荷物の伝票番号は、クロネコヤマトのB2のソフトか、あるいはAccessの業 …

FileMaker Pro 12 での汎用トグルボタンの作り方

Accessではとっても簡単なトグルボタンだが、FileMakerでそれを作るのは簡単ではない。むしろとっても面倒。 それなのに、画面いっぱいにいくつものトグルボタンを作る仕事が出てきた。 一つ一つの …

no image

EPSON EP-4004の有線LAN(インフラストラクチャーモード)での接続方法

EPSON EP-4004のプリンタは、無線LANのアドホックでの接続は、とても簡単。 しかし、インフラストラクチャーでの接続となると、とても難しい。 マニュアルにも、丁寧なやり方は載っていない。 以 …

no image

Excelで使える祝日判定のWebAPIを見つけた

Excelの関数には、曜日を判定できる関数(WEEKDAY)が用意されている。また、表示だけなら書式設定でもできる。しかし祝日となると、関数も何も、用意されていない。 祝日は年により、突然増えたり、「 …

no image

PhotoshopElementsで枠線を書くには

方法が長らくわからなかったが、今日わかったので書いておく。 図形ツールで図形を描く ラスタライズ メニューの「編集」-「境界線を描く」 上記の方法は、操作対象が「境界線」のため、たとえば「選択範囲」- …