Excelには、マクロ機能があり、上手に使うことで自動処理が行える。しかし、デフォルトではマクロを使うための[開発]タブが表示されておらず、マクロの作成や実行が行えない。そこで、[開発]タブを表示させ、マクロの作成と実行が行えるようにしよう。
この記事は会員限定です。会員登録(無料)すると全てご覧いただけます。
対象:Office 2013/2016/2019/365
「Microsoft Excel(エクセル)」では、マクロを使うことで、機能を拡張したり、自動処理が行えたり、新たにワークシートで使える関数などを作ることができるようになったりする。基本的にはプログラミングの素養が必要となるが、マクロを使うことでExcelの世界が広がる。
ただ、セキュリティ的な問題からExcelは、標準状態で[開発]タブが「オフ(非表示)」になっている。これは、指示を受けて意味も分からずマクロを動かしてしまうような操作を避けるためだ。[開発]タブの表示状態は、マクロ起動の可否を決めているのではなく、単にマクロ関連機能にユーザーがアクセスできるかどうかを決めているにすぎない。
また、マクロはかつてOfficeの文書ファイルとともにメールで送られ、「悪意のあるプログラム」を実行させる手段としても使われた。しかし、現在では、マクロの入った文書ファイルは別の拡張子を使い、読み込む前に警告が表示されるなど対策が取られている。
マクロが何であるかを理解して利用するなら、自分でマクロを使うこと自体がExcelのセキュリティを低下させ、「悪意のあるプログラム」を動かしてしまうことにはならない。
日常的にExcelを使うなら、マクロを利用できるようにして、新しい世界の扉を開くのも悪くない。本稿では、マクロの利用に必要になる[開発]タブを表示させ、マクロの入力/実行/保存を簡単に説明する。ただし、マクロのプログラミングに関しては解説しないので、各自で学習していただきたい。
まずは、Excelのマクロ開発に必要な[開発]タブを表示させる。開発タブには、マクロの入力や編集、実行に必要な全ての機能が入っている。
Excelで新規のブックを開き、Excelの[ファイル]タブを開き、左ペインの[オプション]をクリックする。
すると、[Excelのオプション]ダイアログが開くので、左ペインで[リボンのユーザー設定]を選択する。左右に2つのリストが表示されるので、その右側のリストにある[開発]の前にあるチェックを「オン」にして、[OK]ボタンでダイアログを閉じる。
これでExcelのリボンに[開発]タブが表示されているはずだ。なお、これは、Excel自体の設定となるため、今後、他のブックを開いても[開発]タブは表示されたままになる。他人のPCを一時的に操作するような場合、[開発]タブを「オン」にしたら、終了時に元に戻しておこう。標準で「オフ」になっているように、マクロを利用しない人にとっては、[開発]タブは不要だし、マクロを誤って実行してしまったり、間違って操作したりすると、見たこともないウィンドウが表示されるなど混乱が生じる。[開発]タブを非表示に戻す手順は、前記と同じで、チェックを「オフ」にするだけだ。
[開発]タブには、多くのアイコンが並んでいるが、取りあえず使うのは、左側のものだけだ。初めてマクロに触れるような場合なら、必要なのは左側にある「コード」部分の[Visual Basic]と[マクロ]のアイコンに限られる。
[Visual Basic]アイコンは、マクロ(VBAプログラム)を入力したり、編集したりする場合に使う。このボタンを押すと、「Visual Basic Editor(VBE)」ウィンドウが開く。
[A]
[マクロ]アイコンは、マクロを実行したり、デバッグしたりする場合に利用する。クリックすると[マクロ]ダイアログが開く。
なお、Excelは、ユーザーの行った操作をマクロとして記録し、後から再実行したり、編集したりする機能を持つが、ここでは解説しない。
マクロを作るには、[Visual Basic]アイコンをクリックしてVBEを開く。ウィンドウの左側は、現在開いているブックなどのオブジェクトを表し、右側にプログラム(マクロ)を入力する。もちろん、マクロはVBAの文法に沿ったものを入力する必要がある。ここでは、マクロを「作成」「実行」「保存」する手順だけを解説する。
新規にマクロを作る場合、[マクロ]ダイアログから始める方法と、VBEから始める方法の2つがある。手順としては前者の方が簡単で初心者向きだ。ただし、マクロ作成のたびに、その管理単位である「標準モジュール」が増えていって混乱を招きやすい。最初のうちは[マクロ]ダイアログから作成しても構わないが、慣れたら、後者の手順でVBEを直接起動してマクロ作成を開始するようにしよう。
[開発]タブで[マクロ]ボタンをクリックすると、[マクロ]ダイアログが現れる。その[マクロ名]に、作成したいマクロの名前を入れ、[作成]ボタンを押すとVBEが起動する。
例えば、マクロ名として「shioda_test」と入力し、[作成]ボタンを押せば、VBEのコードウィンドウには同名のサブルーチンが作成された状態となる。ただし、作られるのはサブルーチンの枠だけで、中身は何もない。
VBEからマクロ作成を行う場合には、前述の手順でVBEを起動後、[挿入]メニューの[標準モジュール]を選択する。ブックを表すツリーの下に[標準モジュール]が作られ、その下に「Module1」が置かれる。VBEでは、左側のツリー内のオブジェクトをダブルクリックで選択すると、右側の領域は、そのオブジェクトのマクロ編集状態となる。
マクロは、特定のブックやシートに関連するものとしても作成できる。一方、標準モジュールに置くことで、ブック全体で共通して利用することも可能だ。まずは、標準モジュールの「Module1」にマクロを置くため、ここを編集状態とする。なお、[挿入]メニューから「標準モジュール」を選択した直後は、作成された「Module1」が自動的に選択状態になっている。
慣れないうちは、ブックやシートにマクロを書いてしまうことがある。[コード]ウィンドウにマクロを入力する前にプロジェクトエクスプローラーで正しいものを選んでいるか確認する。
この時点では、まだ何も作っていないので、「Module1」は空白のままか、あるいは中身のないサブルーチン(プログラムの中でよく利用する作業などを1つにまとめたもの)が記述されているだけだ。ここにサブルーチンや関数の実体を書き込んでいく。
記述から保存までを実際に試してみるなら、右側の領域に以下のテキストを入力する。非常に簡単ではあるがこれがマクロ(VBAのプログラム)である。
Sub shioda_test()
MsgBox ("Hello World")
End Sub
このマクロには「shioda_test」という名前がついている。それは1行目に記述されている。2行目はメッセージボックスを表示するMsgBox関数だ。3行目はサブルーチンがここで終わることを示すもので、1行目の「Sub」と対になっている。
このマクロを実行するには、Excelの[開発]タブにある[マクロ]ボタンを使う(VBEは閉じてしまっても構わない)。[マクロ]ダイアログが表示され、現在実行可能なマクロの一覧が「マクロ名」に並ぶ。ここでは、もちろん、先ほど入力したマクロ(「shioda_test」)が表示されている。これをリストから選択して「実行」ボタンを押せば、マクロが実行され、「Hello World」と書かれたメッセージボックスが表示される。
最後に、マクロを保存する方法を解説する。マクロは、ブックの中に記録されるため、ブックごと保存しなければならない。しかし、マクロを含むブックは、「マクロ有効ブック」という形式でしか保存できず、通常のブック形式では、マクロを含めて保存できない。なお、VBEにも[保存]ボタンがあるが、Excel側で保存しても、VBE側で保存しても結果的には、ブックの保存なので同じ動作となる。
Excelの[ファイル]タブからブックを保存する。このとき、ファイル形式から[マクロ有効ブック]を選択する。この場合、拡張子は「.xlsm」になる。その他に関しては、通常のブック保存と変わりない。
マクロを入力したブックをマクロ有効ブック以外の形式で保存しようとすると、警告が表示される。これは、「このまま保存するとマクロがブックに含まれない」という意味であり、ブックにマクロがあることも示す。
Excelでの作業時間が多いようなら、マクロについて学んでおくと省力化が可能になる。ただし、インターネットなどから中身の分からないマクロを含むExcelブックなどをダウンロードして動かすなどは、危険な行為といえる。自分で作ったものか、プログラムソースが理解できるものに限定すべきだろう。
また、マクロを作ることが目的化してしまうことがある。筆者も自制してはいるものの、時々、マクロのために長時間プログラミングした結果、省力化という目的から外れてしまうことがある。もちろん、本人が好きならそれでいいのではあるが、まずは多少の距離感を持って付き合う方がいいというのが、長年のExcelユーザーからの忠告である。
Copyright© Digital Advantage Corp. All Rights Reserved.