【Excel VBA】簡単!一度に複数マクロを連続実行するテクニック

記事内に商品プロモーションを含む場合があります。
スポンサーリンク

Excel VBAを使い始めた時「複数のマクロをどうやってまとめて実行すればよいのか?」と悩んだ事はありませんか?

通常何かの処理を行う際は1つの処理だけでなく、複数の処理を組み合わせる事が多いですよね。

しかし複数のマクロを1つずつ手動で実行していくのは手間がかかりますし、1つのマクロに全ての処理を詰め込んでしまうと後からコードを確認するのがとても大変になります。

鳩野

確かに全ての処理順を覚えたり、長々としたコードを後で確認するのは面倒ですよね……。

そこで本記事ではそうした手動で実行する手間を省き、複数のマクロを簡単に連続実行する方法をわかりやすく解説していきます!

やり方はとてもシンプルでいろんな処理に応用できるので、ぜひ覚えておきましょう!

この記事で分かること
  • 一度に複数のマクロを連続して実行する簡単なテクニック
  • マクロを後から見返した時に分かりやすい形でまとめる方法

本記事はMicrosoft 365の環境で解説を行います。

目次
スポンサーリンク

一度に複数マクロを連続実行するテクニック

一度に複数マクロを連続実行する場合、他のマクロを呼び出す為に使用される「call」ステートメントを使ってマクロ内に他のマクロを呼び出しまとめる事で実行できます。

callステートメント

構文:[call] name [argumentlist]

要素内容
call他のマクロ又は関数を呼び出す為に使用、省略可
name呼び出すマクロ又は関数の名称、省略不可
argumentlist呼び出したマクロ又は関数へ渡す引数、省略可

次の項目からこのcallを使ったマクロの呼び出し方について2つの具体例を挙げていきますので処理の用途によってそれぞれ使い分けてみて下さい!

スポンサーリンク

callステートメントを使った複数マクロを連続実行する具体例

この項目では次の2つの具体例を挙げて解説していきます。

callステートメントを使った複数マクロを連続実行する具体例
  • 1つのマクロ内に複数のマクロを呼び出して実行する
  • 各マクロの最後に別のマクロを呼び出して連続実行する

1つのマクロ内に複数のマクロを呼び出して実行する

この方法は日常的な作業や定型的な処理を行う時に向いており、次の様に複数マクロをまとめます。

鳩野

シンプルな形で分かりやすい!

1つのマクロ内で複数のマクロを呼び出して実行するメリット・デメリット

メリット
デメリット
  • 処理がまとまった1つのマクロを実行するだけで複数の処理が可能
  • 1度作成すれば簡単に何度も複数のマクロを実行できる。
  • まとめたマクロ内で簡単に処理順の変更やができ、エラーの特定がしやすい。
  • 呼び出すマクロ自体は個別に独立している為、順番変更時に意図しない結果になる事がある。
  • 各マクロが別々に動く為、単独でテストしたい場合個別に実行する必要がある。

連続した処理を簡単に実行・管理しやすい方法なのでExcel VBA初心者にはおススメです。

スポンサーリンク

各マクロの最後に別のマクロを呼び出して連続実行する

この方法は実行する処理に順序や依存関係がある場合に向いており次の様に書きます。

各マクロの最後に別のマクロを呼び出して連続実行するメリット・デメリット

メリット
デメリット
  • マクロ毎に独立して管理ができる。
  • 各マクロの最後に次のマクロを呼び出すため、処理順が明確に視覚化されて理解しやすい。
  • 処理に依存関係や条件が含まれる場合に向いている。
  • エラーが発生すると、後続のマクロが実行されなくなる可能性がある。
  • 処理順を変更する場合、全てのマクロに対して修正が必要になり手間がかかる。

1つのマクロにまとめた時よりも処理の順序や依存関係を細かく調整する必要があるものの、複数マクロを個別に管理できるといったメリットがあります。

スポンサーリンク

終わりに

以上で今回の解説を終了します。

複数のマクロはcallステートメントで呼び出し、下記の様に記述方法を少し工夫するだけで簡単に連続で実行できます。

  • 簡単で一度に複数の処理を実行したい場合は「1つのマクロ内に他のマクロ呼び出して実行」
  • 処理に依存関係や条件を設定する場合は「各マクロの最後に別のマクロを呼び出して連続実行」

使う場面によって実行できる方法を選ぶ事がポイントとなるので、今回解説した具体例と自分が実行したい処理がどういった処理なのかを一度見比べてみて下さい!

スポンサーリンク

この記事が気に入ったら
フォローしてね!

目次