VBAでプロシージャ間のデータを渡したい
main関数の中でget_Recordという関数を呼んでいます。この中でアクセスの
テーブルからデータを取得して、「this_Hensuu」という変数に格納します。
やりたいことは、get_Recordで取得した変数をmain関数の中で利用したいです。
main()関数外で変数を宣言してグローバル変数とすれば解決するのは
わかりますが、その他の方法でmain関数に値を渡すことは可能でしょうか?
Sub main()
Dim x = 10
Call get_Record(x)
...
...
end sub
Sub get_Record(Byref x As Integer)
Dim rs As Dao.recordset
Dim this_Hensuu As String
Dim this_Hensuu2 As String
get_SQL As String
get_SQL =""
get_SQL="Select * from TABLE1 where ID='" & x & "'"
rs = Openrecordset(get_SQL,opendynaset)
this_Hensuu = rs!名前
this_Hensuu = rs!名前2
end sub
No.2ベストアンサー
- 回答日時:
こんにちは。
Dim x = 10
という書き方は、VBAではないようですし、細かい部分では、他にもエラーが残っているかもしれませんね。別にグローバル変数にしなくても、モジュールにいろんなものを突っ込まなければ、モジュールレベル(Private)でも良いとは思います。関数プロシージャでも、Sub プロージャでも、変数は構造体でも、配列変数でも、そのまま扱っても、それ自体は、どちらでも良いと思います。スタイルとしては、Access の場合は、関数型にすることは多いと思いますが、ご自分で出来るスタイルにしておいて、不具合があれば、その後で換えればよいと思います。
Call get_Record(x)
から、戻してくるなら、
Sub Main()
Dim this_Hensuu As String
Dim this_Hensuu2 As String
Const x = 10
Call get_Record(x, this_Hensuu, this_Hensuu2)
'...
'...
End Sub
Sub get_Record(ByRef x As Integer, this_Hensuu As String, this_Hensuu2 As String)
'Dim this_Hensuu As String ''いらない
'Dim this_Hensuu2 As String ''いらない
Dim get_SQL As String 'Dim を入れる
get_SQL ="" '変数宣言するなら不要かも
get_SQL="Select * from TABLE1 where ID='" & x & "' ;"
rs = Openrecordset(get_SQL,opendynaset)
this_Hensuu = rs!名前
this_Hensuu2 = rs!名前2
とすればよいのでは。なぜ、ByRef x As Integer と、参照渡しにしているのでしょうか?値渡しでも良いと思います。たいしたことではありませんが。
No.1
- 回答日時:
Functionにして、値を返す。
これが、いちばん普通の使い方だと思います。
このとき、Hensuuが2つ有るようなので(HensuuとHensuu2)配列にして返しましょう。
Function get_Record(Byref x As Integer)
Dim rs As Dao.recordset
Dim this_Hensuu(0 To 1) As String
get_SQL As String
get_SQL =""
get_SQL="Select * from TABLE1 where ID='" & x & "'"
rs = Openrecordset(get_SQL,opendynaset)
this_Hensuu(0) = rs!名前
this_Hensuu(1) = rs!名前2
get_Record = this_Hensuu
End Function
で、main側は配列で受け取って使用する。
(例は全角スペースを使用しています。)
ありがとうございます!functionを使えばなんとかなるかなと思っていたのですが、返したい変数が2つあるので、返せないと思っていたのですが、配列を使えばいいんですね。勉強になります、ありがとうございました!
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) access count数を変数に格納 2 2022/03/30 19:21
- Visual Basic(VBA) データベースから絞り込んでデータを読み込み 1 2023/02/21 19:51
- Visual Basic(VBA) 複数のcsvファイルをExcelに一括変換したい 2 2023/03/03 12:44
- Visual Basic(VBA) VBA This Workbookモジュールを別ファイルにコピーする方法 1 2022/09/14 01:51
- Visual Basic(VBA) VBAのユーザーフォームのテキストボックスに入力制限をしたい 6 2022/11/15 08:28
- Access(アクセス) 実行時エラー3131 FROM 句の構文エラーです について 7 2022/06/13 15:45
- Visual Basic(VBA) ①ExcelVBAでカレンダーを作り、別のユザーフォームで日付を入力したいのですがエラーになります。 1 2023/02/17 18:39
- Visual Basic(VBA) VBAでWorkbook.addの使い方 3 2023/02/01 11:58
- Visual Basic(VBA) Vbaで数式をポーランド記法に変換するコードを作って実行しようとするとフリーズします。 1 2022/05/24 17:53
- その他(Microsoft Office) マクロVBAについて 1 2022/09/06 18:12
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
GETメソッドとPOSTメソ...
-
ポインター引数の関数でコンパ...
-
10Mバイトて文字数に すると何...
-
ESC/Pのテキスト印字の制...
-
Rstudioによるテキストマイニン...
-
メールフォームで改行スペース...
-
VB6で漢字の1バイト目か2バイト...
-
CGIを勉強しています。¥n(改...
-
Excel 1セル当りの文字数が2...
-
メールの件名をデコードしたい
-
cgiでの文字化け
-
Excel VBA メール作成について ...
-
int型(2バイト)データの分割
-
sedコマンドで全ての2バイト文...
-
matlabでのRRI検出
-
char str[256]の256の意味は?
-
ログイン後のソースの取得
-
【VB】文字列を50バイトづつに...
-
perlのgrepでmyを付けた場合と...
-
MATLAB(マトラボ)とcsvファ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
POSTメソッドの最大容量について
-
GETメソッドとPOSTメソ...
-
perlのCGIのハッシュを使った、...
-
CGIの変数に配列を代入する方法
-
VBAでプロシージャ間のデータを...
-
ポインター引数の関数でコンパ...
-
10Mバイトて文字数に すると何...
-
UTF-8で5~6バイトになる文字コ...
-
char str[256]の256の意味は?
-
エクセルシート名の制限を変更...
-
DataGridViewの特定列に入力さ...
-
COBOLのCOMP形式について
-
「1TB」のHDDに日本語は何字入...
-
Excel VBA メール作成について ...
-
stable diffusionのエラー
-
Excel 1セル当りの文字数が2...
-
バイナリとBCDコード
-
ビットスワップとバイトスワッ...
-
ピクセル,dpiから容量(バイト...
-
バイト列とバイナリ列の違いが...
おすすめ情報