質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

解決済

1回答

504閲覧

Access VBA : For~Next で取得した値をフィールドに表示する

makosama4493

総合スコア21

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2018/11/13 02:01

ボールドテキスト質問

フォームにあるtemp1フィールドに文字列”apple”が表示されている。
Dlookup関数でappleの個々のアルファベッドに対応するIDを取得し

a....v01
p....c01
l....c02
e....v02

その取得したIDをすべてフォームのフィールドtemp2に表示したい

appleならば temp2=v01c01c01c02v02 というふうに

発生している問題・エラーメッセージ

Debug.print ではappleに対応する全てのIDが表示されますが、 フィールドtemp2には最後の文字「e」に対応するID(v02)しか表示されません。
Private Sub コマンド_click Dim i as integer Dim counter as integer 'フォームにあるtemp1フィールドには文字列"apple"が表示されている counter = len(Me.temp1) → 5を取得 For i = 1 to counter 'Dlookupで取得したIDをフォームにあるフィールドtemp2に表示する Me.temp2 = Dlookup("ID","クエリ名","クエリ項目='"&Mid(Me.temp1,i,1)&"'") next End Sub

試したこと

debug.printに表示されるIDをtempに代入しようとしましたがうまくいきませんでした。

補足情報(FW/ツールのバージョンなど)

Access2016

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

Me.temp2を上書きしているからです。追記にする必要があります。

VBA

1Me.temp2 = Me.temp2 & Dlookup("ID","クエリ名","クエリ項目='"&Mid(Me.temp1,i,1)&"'") 2

投稿2018/11/13 02:12

sazi

総合スコア25195

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

makosama4493

2018/11/13 03:35

素晴らしい!感動!うまくいきました!上書きが原因だとは思いもよりませんでした。 Me.temp2 & で追記になることも初めて知りました。これからのプログラミングにすごく役立ちます。 本当にありがとうございました。
sazi

2018/11/13 04:08

解決済みにして下さいね
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問