初めに
設計書を修正した際など、全ページについて拡大率を100%にしてA1を選択した状態にする、といった儀式を行う方は多いのではないでしょうか。
今回はこの処理をアドインとしてボタン一つで実行できるようにする方法をまとめます。
目標: 「全シートについて拡大率100%に設定してA1を選択状態にして最初のシートに戻る」をボタン一つで実現できるように設定する
全体の流れ
以下の手順で設定します。
- マクロの作成
- アドインの作成
- アドインの登録
1. マクロの作成
目的の機能を実現するマクロをVisual Basic Editor(VBE)を利用して作成します。
まずはマクロを作成するため、空のExcelファイルを開きます。
Excelファイルを開いたら、リボンから開発のタブを選択し、「Visual Basic」を選択します。
※開発タブが表示されていない場合は、以下を参考に設定してください。
- [ファイル] タブ→[オプション]→[リボンのユーザー設定] の順に移動
- [リボンのユーザー設定] → [メイン タブ] の下の [開発] を追加
作成したモジュール(Module1)を選択し、目的の機能を実現するマクロを記述します。
今回は、「全シートについてZoomを100%に設定&A1セルを選択した後に、最初のシートへ移動する」を実現するため以下のようなコードを作成しました。
Sub MoveA1andZoom100()
'シートを定義
Dim ws As Worksheet
'全てのシートで以下をループ
For Each ws In Worksheets
'シートを選択
ws.Select
ws.Activate
ActiveWindow.Zoom = 100
'A1セルを選択
ws.Range("A1").Select
Next
'最初のシートへ移動
Sheets(1).Select
End Sub
※私はVBに明るくないため、上記のコードはChatGPTなどに「Excelのマクロで以下の機能を実現したいです。標準モジュールに記述するコードを作成してください。機能: 全シートについてZoomを100%に設定&A1セルを選択した後に、最初のシートへ移動する」と伝えることで作成してくれたコードを一部利用しています。ただしChatGPTが作成してくれたコードはそのままでは上手く動作しないことが多く、今回も動作確認の上で何回か修正を行いました。動作確認の方法(マクロ実行方法)は以下に記載します。
★マクロの動作確認方法
Excelファイルに戻り、開発タブからマクロを選択。
目的の機能が実現されれば、マクロの作成は完了です。
※アドインとして登録して実行した場合に上手く動作しない場合は再度マクロを修正しましょう。
2.アドインの作成
次に、作成した機能を他のファイルでも実行できるようにアドインを作成します。
Excelファイルへ戻り、「ファイル」→「名前を付けて保存」から、ファイルの種類で「Excel アドイン(*.xlam)」を選択。
この時、アドインの保存場所はC:>Users>(ユーザ名)>AppData>Roaming>Microsoft>AddIns がデフォルトで指定されます。
※ファイル名は作成したマクロと合わせると分かりやすいです。
※また、後にマクロを編集した際に利用できるように、開いているExcelファイルはマクロ有効ブック(.xlsm)として保存しておくのがオススメです。
以上より、C:\Users\(ユーザ名)\AppData\Roaming\Microsoft\AddIns 配下にMoveA1andZoom100.xlamというファイルが作成されていればアドインの作成は完了です。
3. アドインの登録
最後に、アドインを登録します。
まずは、新規Excelファイルを開き、開発タブからEXCELアドインを選択。
今回作成したアドインにチェックし、OKをクリックして有効化します。
次に、クイックアクセスツールバーに設定をします。
下記のように、ユーザ設定を開き、「その他のコマンド」を選択します。
「クイックアクセスツールバー」→コマンドの選択で「マクロ」を選択すると今回作成したマクロがあるので、選択して追加します。
「変更(M)...」からお好みで分かりやすいアイコンに変更します。
OKを押して完了です!
クイックアクセスツールバーに追加されていることを確認しましょう。
✓マークを押下すればマクロが実行されます。
まとめ
以上でクイックアクセスツールバーからボタン一つで、「全シートについて拡大率100%に設定してA1を選択状態にして最初のシートに戻る」を実行できるように設定出来ました。
業務で日々行うお作法などは、上手いこと自動化していきたいですね。
最後までお読みいただきありがとうございました。
参考