こんにちは。
今回、WindowsXP SP2上のExcel2003 VBAを使ってツールを作成しているのですが、
以下のようなエラーが出て手が止まっています。
「コンパイル エラー:
パブリック オブジェクト モジュールで定義されたユーザ定義型に限り、変数に割り当てることができ、実行時バインディングの関数に渡すことができます。」
というものです。
具体的な環境としまして、
標準モジュールにDefineTypeというモジュールを作成し、
Public Type Record
ID As Integer
Name As String
End Type
を定義しています。
これをクラスモジュールに作成したCClassから以下のように参照しています。
Private Detail As New Collection 'of Record
Private Sub Sub1()
Dim rec As Record
rec.ID = 3
rec.Name = "おなまえ"
Detail.Add rec
~~~~~~~~~~~~~~
End Sub
Public Sub CallSub1()
Call Sub1
End Sub
そして、このクラスの中のPublicな関数であるCallSub1を
フォームモジュールから呼び出しているのですが、
Sub1 の Detail.Add がだめなようです。
・このエラーの意味
・どこがどうだめなのか
・どうすれば解決できるか
を、糸口でも構いませんのでご教授下さい。
よろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) エクセルVBAでオブジェクトが必要です 2 2022/09/10 16:37
- Visual Basic(VBA) パーソナルXLSBのfuctionを呼び出すと「Functionが定義されていません」のエラーになる 2 2022/08/22 22:51
- Visual Basic(VBA) マクロについて教えてください。 4 2023/06/06 09:06
- Visual Basic(VBA) 【Excel VBA】自動メール送信の機能追加 5 2022/09/29 12:53
- Visual Basic(VBA) VBA This Workbookモジュールを別ファイルにコピーする方法 1 2022/09/14 01:51
- Visual Basic(VBA) マクロについて教えてください。 1 2023/06/06 00:57
- Visual Basic(VBA) 標準モジュール Public mOnTime As Date Sub sample() '実行プロシ 1 2023/02/22 15:44
- Visual Basic(VBA) Excel・ユーザーフォームの情報を受け渡したい 4 2022/06/08 10:11
- Visual Basic(VBA) batからexeを実行し戻り値を受け取る バッチからEXEの結果を受け取りたいのですが、 下記のバッ 1 2023/07/04 15:13
- Visual Basic(VBA) batからexeを実行し戻り値を受け取る EXEの実行内容の結果によって、戻り値を0か1かで返したい 1 2023/07/04 16:40
このQ&Aを見た人はこんなQ&Aも見ています
-
新NISA制度は今までと何が変わる?非課税枠の拡大や投資対象の変更などを解説!
少額から投資を行う人のための非課税制度であるNISAが、2024年に改正される。おすすめの銘柄や投資額の目安について教えてもらった。
-
エクセルのラベルの値(文字列)を垂直方向で中央揃えにするには?
Excel(エクセル)
-
VB6でユーザー定義型がNothingかどうか調べるには?
Visual Basic(VBA)
-
VBで構造体の配列を関数に渡す方法?
Visual Basic(VBA)
-
-
4
エクセルVBA クラスモジュール内でパブリックユーザ定義型
Visual Basic(VBA)
-
5
構造体配列の特定のメンバーをFor~Eachで
Visual Basic(VBA)
-
6
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
7
VBで引数にDictionaryオブジェクトを使用する方法
Visual Basic(VBA)
-
8
戻り値がクラスオブジェクト
Visual Basic(VBA)
-
9
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
10
どこにもフォーカスを当てたくない
Access(アクセス)
-
11
Application.ScreenUpdating = Falseが効きません
Visual Basic(VBA)
-
12
array関数で格納した配列の型を変更する
Visual Basic(VBA)
-
13
VBA public変数はどのようなことをしたら解放されますか?
Visual Basic(VBA)
-
14
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
15
クラスのプロパティに構造体を使いたい。
Visual Basic(VBA)
-
16
Excelの入力規則で2列表示したい
Excel(エクセル)
-
17
エクセルのエラーメッセージ「400」って?
Visual Basic(VBA)
-
18
Access コンボボックスの値をクリアしたい。
PowerPoint(パワーポイント)
-
19
構造体→文字列→構造体 をする方法
Visual Basic(VBA)
-
20
関数の引数に複数のユーザ定義型変数を使いたい
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ArduinoのジャイロモジュールMP...
-
Excel VBA 定義されたプロージ...
-
グラフのX,Y座標を取得したい
-
【vba】フォームに書いてあ...
-
VBでグローバル変数を宣言するには
-
VBAで別モジュールへの変数の受...
-
印刷後メッセージボックスを表...
-
VBAを使用してWordからExcelの...
-
VBAで旧字体を異字体に一括で変...
-
モジュールとは何ですか
-
VBA This Workbookモジュール...
-
Excel VBAでリンク切れをチェッ...
-
プラグイン、ライブラリ、コン...
-
Excel VBA 標準モジュール内で...
-
大量の標準モジュールを解放す...
-
モジュールからフォームのボタ...
-
偶数/奇数の判定
-
ユーザー定義関数に#NAME?が返...
-
AddressOf と同じ機能を持った...
-
CPANのインストールモジュール...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel VBAでリンク切れをチェッ...
-
ユーザー定義関数に#NAME?が返...
-
VBAで別モジュールへの変数の受...
-
VBでグローバル変数を宣言するには
-
エクセルVBAでシートモジュール...
-
VBA This Workbookモジュール...
-
モジュールの最大数はいくつな...
-
Excel VBAで、ユーザーフォーム...
-
VBAで旧字体を異字体に一括で変...
-
Access VBA標準モジュールにつ...
-
VBA モジュールで共通に使う変...
-
'Range'メソッドは失敗しました
-
グラフのX,Y座標を取得したい
-
モジュールとは何ですか
-
Excel VBA 『Call』で呼び出す...
-
プラグイン、ライブラリ、コン...
-
【vba】フォームに書いてあ...
-
モジュールからフォームのボタ...
-
モジュールとクラスの違いって...
-
acwzlibとは?
おすすめ情報