
次のようなVBAのコードをご指南ください。
実行すると、アクティブブックのモジュール内で定義されたサブプロージャ名や関数名を、種類とそれが定義されたモジュール名を併記する形で、メッセージボックスで一覧表示するマクロ。
実行結果のイメージ
Sheet1 (****) プロージャー procA()
Sheet1 (****) プロージャー procB()
ThisWorkbook イベントプロージャー workbook_open()
標準モジュール プロージャー test()
標準モジュール 関数 func(hikisuA As Long, hikusuB As String)
他者がつくったマクロファイルが複雑で、モジュールがたくさんあります。どのモジュールにマクロが定義されているか、VBEを開いて1つ1つモジュールをダブルクリックして調べるのが面倒です。情報を得るのが目的なので、実行結果のイメージに深いこだわりはありません。詳しい方、よろしくお願いします。
No.1ベストアンサー
- 回答日時:
こんにちは
モジュールからプロシージャを抜き出す簡単な方法をざっと探してみましたが、見つからなかったので、以下は1行ずつ調べるというローテクな方法です。
事前に設定した(=変数pre)に該当する Sub、Function を抜き出しますので、ClassやDeclare、Proparty、Enumなどは無視します。
>メッセージボックスで一覧表示するマクロ。
対象が多い場合に、メッセージボックス表示ではあんまりと思いますので、ActiveSheetのA、B列に一覧を列挙するようにしてあります。
また、モジュール名はオブジェクト名になりますので、シートの表示名とは異なる可能性があります。
(シート名表示の方が良ければ、読み替えを追加してください)
以下、ご参考までに。
Sub Q13781167()
Dim i As Long, j As Long
Dim rg As Range, s As String
Dim pre, t, m, p
pre = Split("Sub ,Private Sub ,Public Sub ,Function ,Private Function ,Public Function ", ",")
Columns("A:B").ClearContents
Set rg = Range("A1:B1")
rg.Value = Array("[Module Name]", "[Proc Name]")
For Each t In Array(100, 1, 3)
For Each m In ActiveWorkbook.VBProject.vbcomponents
If m.Type = t Then
If rg(1).Value <> "" Then Set rg = rg.Offset(1)
rg(1).Value = m.Name
For j = 1 To m.codemodule.CountOfLines
s = m.codemodule.Lines(j, 1)
For Each p In pre
If Left(s, Len(p)) = p Then rg(2).Value = s: Set rg = rg.Offset(1): Exit For
Next p
Next j
End If
Next m
Next t
End Sub
教えてくださりありがとうございます。教えていただいたコード、私の環境でも実行でき期待した結果が得られました。回答をいただいて、コードの中身を理解するのに時間がかかり、お礼がたいへん遅くなりましたが、とても参考になりました。
m.codemodule.CountOfLinesやs = m.codemodule.Lines(j, 1)
などのcodemoduleは一度も目にしたことがありませんでした。
それから、選択範囲rgのOffsetの利用の仕方が秀逸です。Arrayの使い方も参考になりました。preをSplitで定義することで、多条件の場合分けを可能にしている点も参考になりました。
たくさんの工夫が詰め込まれたコードを教えていただきました。どこまで使いこなせるかわかりませんが、他のコードにも利用できるように勉強していきたいと思います。ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
VBA プロシージャの名前の取得
その他(Microsoft Office)
-
プロシージャ名の取得
Visual Basic(VBA)
-
VBAでブックを非表示で開いて処理して閉じる方法
Excel(エクセル)
-
-
4
【VBA-AC2000】カレントプロシージャ名を取得したい
Visual Basic(VBA)
-
5
Excelマクロで、稼働中のマクロを確認する方法
その他(Microsoft Office)
-
6
或るプロシージャの呼び出し元判定
その他(Microsoft Office)
-
7
VBAのエラー発生場所をメッセージBOXに表示
Visual Basic(VBA)
-
8
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
9
VBA 変数名に変数を使用したい。
Visual Basic(VBA)
-
10
エクセルVBAでプロシージャ名を取得したい
Excel(エクセル)
-
11
ADO+ODBCでテーブルに接続する時のエラー
MySQL
-
12
エクセルのラベルの値(文字列)を垂直方向で中央揃えにするには?
Excel(エクセル)
-
13
指定のWORKBOOKを前面表示する方法(エクセル:VBA)
Excel(エクセル)
-
14
Integer変数をカラにしたいのですが
Visual Basic(VBA)
-
15
ユーザーフォームで動的(Me.Controls.Add)に作成したコントロールの削除
Visual Basic(VBA)
-
16
UserForm1.Showでエラーになります。
工学
-
17
SQL文で パラメータが少なすぎます エラー
Access(アクセス)
-
18
【VBA】エラー処理で別プロシージャに飛ばす方法
Visual Basic(VBA)
-
19
VBAでワークシートを引数としてサンプル関数に渡したい
Visual Basic(VBA)
-
20
表にフィルターをかけ、絞ったデータ(可視化セルのみ)を一次元配列として変数に入れるという動作を書きた
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excel VBAで、ユーザーフォーム...
-
エクセルVBA クラスモジュール...
-
印刷後メッセージボックスを表...
-
Visual Basicプログラムのエラ...
-
エクセルVBAでシートモジュール...
-
モジュールの最大数はいくつな...
-
VBでグローバル変数を宣言するには
-
ユーザー定義関数に#NAME?が返...
-
acwzlibとは?
-
【vba】フォームに書いてあ...
-
ユーザーフォーム上に表示され...
-
Perlでモジュールをインストー...
-
Tomcat マイナーバージョン移行...
-
Excel VBAでリンク切れをチェッ...
-
クラスモジュールを使わないと...
-
Excel VBA 定義されたプロージ...
-
ExcelVBA:パブリック オブジェ...
-
VBのフォームモジュールと標準...
-
VBA This Workbookモジュール...
-
Form間の値の渡し方
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel VBAでリンク切れをチェッ...
-
エクセルVBAでシートモジュール...
-
VBでグローバル変数を宣言するには
-
ユーザー定義関数に#NAME?が返...
-
Excel VBAで、ユーザーフォーム...
-
Excel VBA 定義されたプロージ...
-
vba userFormのSubを標準モジュ...
-
標準モジュールを削除したい。(...
-
'Range'メソッドは失敗しました
-
VBAで別モジュールへの変数の受...
-
モジュールからフォームのボタ...
-
モジュールの最大数はいくつな...
-
グラフのX,Y座標を取得したい
-
モジュールとクラスの違いって...
-
【vba】フォームに書いてあ...
-
Form間の値の渡し方
-
VBのフォームモジュールと標準...
-
VBA モジュールで共通に使う変...
-
Excel VBA 『Call』で呼び出す...
-
acwzlibとは?
おすすめ情報