プログラミング不要でRPA、「マクロの記録」機能でExcelを自動化するTech TIPS

Excelのマクロと聞くと、VBAやプログラミングの知識が必要と思ってしまい、敬遠している人も少なくないようだ。しかし、VBAやプログラミング知識がなくてもマクロを作ることができる。その方法を解説しよう。

» 2020年11月09日 05時00分 公開
[塩田紳二]

この記事は会員限定です。会員登録(無料)すると全てご覧いただけます。

「Tech TIPS」のインデックス

連載目次

対象:Office 2013/2016/2019/365


Excelのマクロの作成にはVBAの知識は不要? Excelのマクロの作成にはVBAの知識は不要?
Excelのマクロと聞くとVBAやプログラミングの知識が必要と思い込んでいる人が少なくない。しかし、VBAやプログラミング知識がなくてもマクロは作ることができる。

 「Microsoft Excel(エクセル)」のマクロと聞くと「プログラミングができないとダメ」「VBAの勉強が必要」と思っている人が多いようだ。実は、「マクロの記録」を使い、一定のルールに従って操作を記録することで、プログラミングやVBAの知識がなくても、マクロを作ることができる。

 もちろん、「マクロの記録」では、VBAやプログラミングの知識を使って作成するマクロに比べて制限はある。しかし、リボンのボタンを複数押すような処理をマクロ化するには、VBAやプログラミングの知識は「まったく」必要ない。

 日常的なExcelの使い方を考えてみても、リボンの同じボタンの組み合わせを何回も繰り返し押していることがあるはずだ。こうした操作はプログラミングを知らなくてもマクロ化することで作業の工数を減らすことができる。

 例えば、Excelで表を作るとき、表の見出し部分を「太字」にして「中央揃え」といった作業をしていないだろうか? 日付に対していつも年月日や元号による書式を設定していないだろうか? こうした作業は全てマクロとして記録できる。一回マクロを作ってしまえば、これをリボンに登録して、ボタン1つで実行させることが可能になる。

マクロを記録する際の制限

 「マクロの記録」機能は、ユーザーが行った操作をExcelがマクロとして記録するものだ。作業によっては、書き換えないとマクロとしては使い物にならない場合もある。しかし、以下のルールに従って操作を記録すれば、マクロを編集する必要がないため、プログラミングの知識は必要ない。重要なポイントは以下の2点だ。

  • リボンにあるボタンで実行できる機能だけを使う
  • 「セル」「シートタブ」「ブック」「ウィンドウ」を選択する操作は行わない

 もう少し具体的な例で、避けた方がよい「マクロの記録」時の操作について触れておこう。

セルやシートタブのクリックは行わない

 セルやシートを選択する操作を含めることはマクロの編集なしには難しいので、「マクロの記録」中は、セルやシートタブのクリックを行ってはいけない

 その一方で、[リボン]タブを切り替える操作は可能で、ダイアログが表示される機能も利用できる。

セル範囲の選択は利用しない

 また、キーボードショートカットもリボンに同等のボタンがあるものは使えるが、セル範囲を選択するようなもの(例えば、表を選択する[Ctrl]+[A]キーなど)は利用しないこと。このあたりは区別が難しいので、キーボードショートカットは利用できないと理解しておいた方がいい。

値や数式の入力はアクティブセルのみ

 セルに値や数式を入れる操作は、いつでも同じ数値や文字列、またはセル参照を含まない数式ならば可能である。ただし、値や数式の入力は、アクティブセルにしか行えないことに注意が必要だ。やはり区別がよく分からないという場合には、セルに値や数式を入れることはできないと考えてもよいだろう。

新規のシートや他のブックが開いたら「マクロの記録」は終了

 画像やグラフ、数式、コメントなどの挿入、ピボットテーブル、クエリ、ブックを開く操作など、実行すると新規にブックやシートが開いたり、アクティブセルが移動したり、非選択状態になったりする機能も利用は可能だ。ただし、それ以降の操作は、セル範囲が選択されていない状態で記録を行う必要がある。基本的には、実行した機能で、新規シートや他のブックなどが開いたら、そこで「マクロの記録」は終了と考えてほしい。

ダイアログに対する操作は記録時の値に固定される

 ダイアログでの機能の選択は普通に行って問題ないが、「ファイルを開く」「保存するときのファイル名」「パス指定」や、「検索や置換時の文字列」「ユーザー定義書式文字列」などは、記録したときに入力、適用した値に固定される。[名前を指定して保存]ダイアログの操作を記録したマクロでは、常に同じ名前のブックファイルを同じフォルダに保存することになる点に注意してほしい。

「マクロの記録」の使い方

 「マクロの記録」をする上での注意点を理解したところで、実際にマクロを作成する手順を紹介しよう。

【準備】リボンに[開発]タブを加えておく

 「マクロの記録」だけなら[表示]タブの[マクロ]−[マクロ記録]でも開始できるが、その後にマクロの名前を変えるなどさまざまな操作をするときには[開発]タブを使う方が便利だ。

 そこで事前準備として[開発]タブを表示させておく。[開発]タブは、デフォルトでは非表示状態なので、Tech TIPS「Excel自動化への第一歩 マクロ(VBA)を使えるようにする」を参照して、[開発]タブを表示しておいてほしい。

【準備】空白のブックファイルだけを開く

 次に、空白のブックでExcelを起動する。マクロは、マクロ有効ブックなどにしか保存できないので、既存のブックファイルなどは閉じておく。なお、この空白のブックは、Excelを起動し、データの入ったブックにマクロが記録されてしまう事故を防ぐためだけのものなので、作業が終わったら保存する必要はない。

【準備】操作したいセルを選択する

 「マクロの記録」を行う前に、対象となるセル範囲を作っておく。どんな操作を記録するかにもよるが、「書式設定」などは、セルに値が入っていないと、効果を見ることができない(行った操作が実行されているのかが分かりにくい)。効果を見ることができるならば、値は適当なもので構わない。

 値を入れたら、複数行、複数列のセルを含むセル範囲を選択状態とする。セル範囲を選択状態とすることで、記録される操作は全てセル範囲を対象とするものになる。

 ただし、「セルに固定した値を入れる」「セル参照を含まない数式を入れる」という場合には、セル範囲ではなく単独の空白セルを選択状態とする。単独セルを選択した状態で「マクロの記録」を行うと、記録されるマクロは、アクティブセルを対象とするものとして記録され、セル範囲を選択した場合と挙動が変わることがある点に注意してほしい。

マクロの記録を始める

 準備ができたら、[開発]タブの[コード]−[マクロの記録]ボタンを押す。[マクロの記録]ダイアログが表示されるので、「マクロの保存先」のプルダウンリストで[個人用マクロブック]を選択する。「マクロ名」や「説明」はそのままでも問題ない。

 マクロに名前を設定した場合、同じブックに含まれるマクロの名前は重複できないので、「マクロの記録」をやり直すときには別の名前を付けるか、削除する必要がある。[マクロの記録]ダイアログでは、「Macro1」から末尾の数字を増加させた重複しない名前が提示されるので、基本的にはそのままでも問題ない。

マクロの記録を開始する方法 マクロの記録を開始する方法
「マクロの記録」を使うには、[開発]タブの[マクロの記録]をクリックして、[マクロの記録]ダイアログを表示させ、[OK]ボタンを押して開始させる。「マクロ名」や「説明」「ショートカットキー」は何も設定しなくてもよい。ただし「マクロの保存先」を[個人用マクロブック]にしておく。

 [OK]ボタンを押すと記録が始まる。といっても、ビデオなどの記録とは違い、何もしなければ何も記録されないので、慌てる必要はない。必要な操作をゆっくりと行えばよい。また、リボンタブの選択など、セルやシートに変更が加わらない操作は記録されないので、タブを間違えた場合はそのまま正しいリボンタブを選択し直せばよい。

 違った操作をしてしまうと、やり直しするしかないので、記録を始める前に一回予行をしておくとよい。操作手順をメモ帳などに書いておき、見ながら記録するのもいいだろう。

マクロの記録を終了する

 必要な操作が終わったら、[開発]タブの[コード]−[記録終了](最初に「マクロの記録」ボタンがあった位置)を押し、「マクロの記録」を終了する。これでマクロが記録された。

マクロの記録を終了する方法 マクロの記録を終了する方法
必要な操作を記録したら、[開発]タブの[記録終了]をクリックして、「マクロの記録」を終了させる。

具体的にマクロを作ってみる

 ここでは、実際のExcelの操作を交えて、マクロを作りながら手順を紹介しよう。簡単な例として、選択範囲のセルに「罫線」を引いて、セルの表示を「中央揃え」、「上下中央揃え」とするマクロを作ってみる。

 複数のセルに適当に値を入れる。これは、書式を確認するものなので、「a」「b」「c」など適当のものでよい。「罫線」の状態を確認できるように、複数列、複数行のセル範囲を選択状態としておく。この準備は必須ではないが、状態を確認しやすくするためのものだ。その後、下画面の手順を実行することでマクロを作ることができる。

「マクロの記録」の実行手順(1) 「マクロの記録」の実行手順(1)
あらかじめマクロの処理対象となるセル範囲を選択しておく。ここには、記録する操作の効果が見えるように適当な値を入れておくとよい。その後、「マクロの記録」を開始する。
「マクロの記録」の実行手順(2) 「マクロの記録」の実行手順(2)
[マクロの記録]ダイアログが開いたら、適当な「マクロ名」を入力する(デフォルトの「Macro1」のままでもよい)。また、「マクロの保存先」には、[個人用マクロブック]を選択する。「説明」は何も入力しなくてもいいが、後からどのような操作をするマクロなのかが分かるように、操作内容を入力しておくとよい。
「マクロの記録」の実行手順(3) 「マクロの記録」の実行手順(3)
[ホーム]タブを選択し、[上下中央揃え][左右中央揃え]を順番にクリックから、[罫線]ボタンをクリックしてメニューの[格子]と[太い枠線]を順番(青丸の順番)にクリックした後、「マクロの記録」を終了させる。

 これで「表作成」マクロができた。途中で間違えてしまった場合、[開発]タブの[コード]−[記録終了]をクリックして記録を止め、同じ手順でやり直す。このとき、[マクロの記録]ダイアログでは、前回と違う「Macro2」などの名前に変更する必要がある。

 では、マクロを実行してテストしてみよう。「マクロの記録」前と同じく、適当に値を入れた複数列、複数行のセル範囲を新たに作成して選択状態にしておく。[開発]タブの[コード]−[マクロ]をクリックして、表示される[マクロ]ダイアログで[PERSONAL.XLSB!表作成]を選択して、[実行]ボタンを押す。「PERSONAL.XLSB」は「個人用マクロブック」のファイル名である。

記録したマクロを実行する方法(1) 記録したマクロを実行する方法(1)
作成したマクロを実行するには、[開発]タブの[マクロ]をクリックする。
記録したマクロを実行する方法(2) 記録したマクロを実行する方法(2)
[マクロ]ダイアログで実行したいマクロを「マクロ名」リストから選択して、[実行]ボタンを押す。

作成したマクロを保存する

 マクロを作成した「個人用マクロブック」を保存する。それには、[開発]タブの[コード]−[Visual Basic]をクリックして、Visual Basic Editor(以下VBE)を開く。VBEウィンドウ左側のツリーから「VBProject(PERSONAL.XLSB)」を選択して、[ファイル]メニューの[PERSONAL.XLSBの上書き保存]を選択する。

記録したマクロを保存する方法(1) 記録したマクロを保存する方法(1)
作成したマクロを「個人用マクロブック」で保存するには、[開発]タブの[Visual Basic]をクリックして、Visual Basic Editorを起動する。
記録したマクロを保存する方法(2) 記録したマクロを保存する方法(2)
VBEの左側のツリーから[VBProject(PERSONAL.XLSB)]を選択する。
記録したマクロを保存する方法(3) 記録したマクロを保存する方法(3)
[ファイル]メニューの[PERSONAL.XLSBの上書き保存]を選択するか、ツールバーの[保存]ボタンや[Ctrl]+[S]キーを押してもよい。

 個人用マクロブックは、次回以降のExcel起動時に自動的に開くようになるので、記録したマクロがいつでも利用できる。便利に使うにはリボンをカスタマイズしてマクロを登録するとよい。その方法は、Tech TIPS「【Excel】『あの機能はどのタブだっけ?』を自分専用リボンで解決」を参考にしてほしい。

 「マクロの記録」でも一定のルールを守れば、編集が不要なマクロを作成できる。実際にExcelを操作して、その手順を記録させるだけなので、プログラミングの知識は不要だ。繰り返し行う作業は、マクロ化すれば1クリックで実行可能になる。

Copyright© Digital Advantage Corp. All Rights Reserved.

スポンサーからのお知らせPR

注目のテーマ

Microsoft & Windows最前線2025
AI for エンジニアリング
ローコード/ノーコード セントラル by @IT - ITエンジニアがビジネスの中心で活躍する組織へ
Cloud Native Central by @IT - スケーラブルな能力を組織に
システム開発ノウハウ 【発注ナビ】PR
あなたにおすすめの記事PR

RSSについて

アイティメディアIDについて

メールマガジン登録

@ITのメールマガジンは、 もちろん、すべて無料です。ぜひメールマガジンをご購読ください。