アプリ版:「スタンプのみでお礼する」機能のリリースについて

お世話になります。

EXCELで「Visual Basic Editor」を開くと、
左側に下記が表示されます。

Microsoft Excel Objects > Sheet1、Sheet2、Sheet3、ThisWorkBook
フォーム > UserForm1
標準モジュール > Module1
クラス モジュール > Class1

Sheet1やUserForm1、Module1、Class1にそれぞれコードを
入力できますが、違い、使い分けについて教えてほしいです。
どれにコードを書いていけばいいか分からず困っています。

よろしくお願いします。

A 回答 (3件)

こんばんは。



一応、前のご質問からすると、「マクロの入門者」ですとなっていましたが、私も、入門時にはさっぱり分かりませんでしたね。

大きく別けると、三つに分かれると思います。

・標準モジュール
・クラスモジュール
・ローカルモジュール(≒オブジェクトモジュール)
 (シート, UserForm, ThisWorkbook)

となっています。

「標準モジュール」に書いておくと、ちょうど、家の中で、家族全員が集まるような居間で、そこで声を掛けると、一通り、どこにでも声が届くようになっています。つまり、どこか特定のオブジェクトに関連付けられておりません。個々のオブジェクト(シートやUserForm)からでも、自由に取り出しが利きます。Excelでは、基本的には、「標準モジュール」に書いてください。時々、シートモジュールなどに、ごちゃごちゃ書く人がいますが、それは間違いです。

「標準モジュール」に書けば、シートを転々と動かしても、その親オブジェクトは、指定しなければ、ActiveSheet になっています。「ローカルモジュール」では、違う場所の場合は、シートなどを指定しなくてはなりません。そうしないとは、エラーが出ることが多いです。
そういう点で、「標準モジュール」は、ローカルに対して、「グローバル」だと思ってよいと思います。共通する定数や変数を置く場合も、そこに書きます。(厳密な意味での「グローバル」というのは、また違いますから、いずれ、あのとき、掲示板の回答者の言ったことはウソだったなんて思わないでください。「グローバル」というのは、本当に、どこからでも、ということになるのですが、一般的な方法では、同じブック内だけしか呼び出しが利かないと思ってください。)

「ローカルモジュール」は、その親オブジェクトが、シート(Sheet1)だったり、UserFormだったりします。ThisWorkbook というのは、そのブック全体の入り口のような場所です。多くは、その親オブジェクト固有のコードが多く、イベント・ドリブン型と言って、オブジェクト自体を操作したときに起動することで動かすマクロのために使います。

UserForm も同じです。UserForm のそれぞれのコントロール(ボタンやテキストボックスなど)を動かすときに起動するマクロを書き込みます。

「クラスモジュール」は、それ自身が、固有のオブジェクトとなり、プロパティやメソッドを記述することが可能です。オブジェクトの設計図のような場所で、オブジェクトの動作をコントロールすることが出来ます。例えば、新しいブックを開いたときに、デフォルトをユーザーの思うような仕様にしたいというようなことも、機能的に許されれば可能です。

しかし、「クラスモジュール」は、Excelでは多くは、上記のローカルモジュールと同じようなイベント・ドリブン型の、ユーザー設定したものを、コントロールに付け加えるときが多いです。
    • good
    • 0

普通初学者はModule1にコードを書く。


イベント(何何した(事象が起こった)ときのチャンスを捉える)場合、はその事象の起こるシートのSheetXを選ぶ。
ユーザーフォーム(台紙)を使う場合はUserForm1
クラス モジュール は当面対象外。
    • good
    • 0

> どれにコードを書いていけばいいか分からず困っています。


というレベルであれば、標準モジュールに書いておけば間違いないです。
そのうちに、シートモジュールとかのことを徐々に勉強していくことになると男観ます。
    • good
    • 0

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!