
ユーザーフォーム「frm_基本❶」を立ち上げると新規で入力する行数を右下のNoとして表示しています。
既にシート3行目の「田中博」の追加情報を別のユーザーフォーム「frm_旅行」で入力するため、検索リストから「田中博」を選択し、「frm_基本❷」に表示後、「旅行」ボタンをクリックし「frm_旅行」に表示させたいのですができません。新規行数の「4」となってしましまいます。何処を修正したら良いか教えてください。
<frm_基本のコード>
Private Sub 旅行_Click() '← 検索ボタン押下時の処理追加
frm_旅行.Show vbModal '← 旅行フォームを表示する
If rtnNo > 1 Then
'検索フォームから渡された行番号のデータをセットする
With Worksheets("master")
Me.lbl行番号.Caption = rtnNo
Me.txt_氏名 = .Cells(rtnNo, 3)
End With
End If
End Sub
Private Sub UserForm_Initialize() '← フォームを表示した時の処理追加
'行番号ラベルに最終行+1をセット
Me.lbl行番号.Caption = Worksheets("master").Range("B1").CurrentRegion.Rows.Count + 1
End Sub
Private Sub cmd検索_Click() '← 検索ボタン押下時の処理追加
frm検索.Show vbModal '← フォームを表示する
If rtnNo > 1 Then
'検索フォームから渡された行番号のデータをセットする
With Worksheets("master")
Me.lbl行番号.Caption = rtnNo
Me.txt_氏名 = .Cells(rtnNo, 3)
Me.txt_住所 = .Cells(rtnNo, 4)
Me.txt_電話番号 = .Cells(rtnNo, 5)
End With
End If
End Sub
Private Sub cmd_save_Click() '← 登録ボタン押下時の処理
Dim wRow As Long
'フォーム上の各データをシートへ送る
With Worksheets("master")
wRow = Me.lbl行番号.Caption
.Cells(wRow, 9) = Me.txt_氏名
.Cells(wRow, 24) = Me.txt_住所
.Cells(wRow, 26) = Me.txt_電話番号
End With
Unload Me
End Sub
Private Sub cmd_close_Click()
Unload Me
End Sub
<frm_検索のコード>
Private Sub UserForm_Initialize() '← フォームを表示した時の処理追加
rtnNo = 0 '← フォーム間のデータ受け渡し用変更の初期化
Call SetListBox '← リストボックスに表示する処理を実行(下部に処理記述)
End Sub
Private Sub txt_氏名_Change() '← 検索する氏名を入力した時の処理追加
Call SetListBox '← リストボックスに表示する処理を実行(下部に処理記述)
End Sub
Private Sub lst_リスト_DblClick(ByVal Cancel As MSForms.ReturnBoolean)
rtnNo = Me.lst_リスト.Text 'リストボックスから氏名をダブルクリック選択した時の処理追加
Unload Me '← フォームを閉じる
End Sub
Private Sub SetListBox() '← リストボックスに表示する処理追加
Dim wRow As Long
Dim wLstRow As Long
Me.lst_リスト.Clear '← リストボックスを初期化
wLstRow = 0
For wRow = 2 To Worksheets("master").Range("B1").CurrentRegion.Rows.Count
If Me.txt_氏名 = "" Then
'検索する氏名が入力されていない場合は、
'「master」シートの2行目~最終行の行番号と顧客名をリストボックスにセット
Me.lst_リスト.AddItem ""
Me.lst_リスト.List(wLstRow, 0) = wRow
Me.lst_リスト.List(wLstRow, 1) = Worksheets("master").Cells(wRow, 3)
wLstRow = wLstRow + 1
Else
If InStr(1, Worksheets("master").Cells(wRow, 3), Me.txt_氏名, vbTextCompare) > 0 Then
'検索する対象者名が一部一致した場合、行番号と対象者名をリストボックスにセット
Me.lst_リスト.AddItem ""
Me.lst_リスト.List(wLstRow, 0) = wRow
Me.lst_リスト.List(wLstRow, 1) = Worksheets("master").Cells(wRow, 3)
wLstRow = wLstRow + 1
End If
End If
Next
End Sub

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) ユーザーフォームの表示を追加したい 2 2023/03/26 23:18
- Visual Basic(VBA) 検索のユーザーフォームの表示について 1 2023/03/27 23:31
- Visual Basic(VBA) いつもお世話になっております、VBAで教えて頂きたいのですが 2 2022/05/05 22:20
- Visual Basic(VBA) VBA Userformで一部別シートに転記がしたいのですが 2 2023/05/24 13:08
- Visual Basic(VBA) VBA処理追加 こちらでご教示頂いたのですが回答完了させてしまいましたのでこちらからまた質問させてく 2 2022/10/27 09:57
- Visual Basic(VBA) VBAで質問ですが、皆さんはどの様に導き出しているのでしょうか? 6 2022/05/03 21:53
- Excel(エクセル) VBAの指示の内容 昨日こちらでご教示頂いたのですが初心者な為、一つ一つの指示が何をやっているのかわ 2 2022/10/25 18:08
- Visual Basic(VBA) ①ExcelVBAでカレンダーを作り、別のユザーフォームで日付を入力したいのですがエラーになります。 1 2023/02/17 18:39
- Visual Basic(VBA) 【前回の続き続きです、ご教示ください】VBAの記述方法がわかりません。 2 2022/08/24 20:49
- Visual Basic(VBA) ユーザーフォームに2つのコンボボックス銀行名「ConboBox1」支店名を「ConboBox2」とし 4 2022/08/03 17:34
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一番好きなみそ汁の具材は?
- ・泣きながら食べたご飯の思い出
- ・「これはヤバかったな」という遅刻エピソード
- ・初めて自分の家と他人の家が違う、と意識した時
- ・いちばん失敗した人決定戦
- ・思い出すきっかけは 音楽?におい?景色?
- ・あなたなりのストレス発散方法を教えてください!
- ・もし10億円当たったら何に使いますか?
- ・何回やってもうまくいかないことは?
- ・今年はじめたいことは?
- ・あなたの人生で一番ピンチに陥った瞬間は?
- ・初めて見た映画を教えてください!
- ・今の日本に期待することはなんですか?
- ・集中するためにやっていること
- ・テレビやラジオに出たことがある人、いますか?
- ・【お題】斜め上を行くスキー場にありがちなこと
- ・人生でいちばんスベッた瞬間
- ・コーピングについて教えてください
- ・あなたの「プチ贅沢」はなんですか?
- ・コンビニでおにぎりを買うときのスタメンはどの具?
- ・おすすめの美術館・博物館、教えてください!
- ・【お題】大変な警告
- ・洋服何着持ってますか?
- ・みんなの【マイ・ベスト積読2024】を教えてください。
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・最強の防寒、あったか術を教えてください!
- ・歳とったな〜〜と思ったことは?
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「ご処理進めて頂きますようお...
-
エクセルで、日付を入力すると...
-
VBAでループ内で使う変数名を可...
-
月度は何て読みますか?
-
【Excel】特定の文字を含むセル...
-
DoEventsがやはり分からない
-
お家デートをしててハグを長い...
-
セックスレスの既婚女性は自慰...
-
UMLでの例外処理
-
インタラクティブの反対語は?
-
Do~Loopした回数をカウントしたい
-
VBAでセルに値が入力されるまで...
-
EXCEL VBA マクロ 実行する度に...
-
エクセルVBA マクロ処理中のポ...
-
ボタンクリックイベント 重複...
-
タッチパッドはチャタリングは...
-
VBの質問#if 0 then ってどう...
-
findは動くがfindnextがマクロ...
-
メルカリのメルカードで買い物...
-
RPGプログラムの*HIVALについて
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「ご処理進めて頂きますようお...
-
エクセルで、日付を入力すると...
-
VBAでループ内で使う変数名を可...
-
【Excel】特定の文字を含むセル...
-
DoEventsがやはり分からない
-
UMLでの例外処理
-
EXCEL VBA マクロ 実行する度に...
-
月度は何て読みますか?
-
FFTの結果ついて
-
VBの質問#if 0 then ってどう...
-
お家デートをしててハグを長い...
-
switch の範囲指定
-
Loadイベント中にほかのイベン...
-
インタラクティブの反対語は?
-
VB.NET Excelを読み込んでDataT...
-
Do~Loopした回数をカウントしたい
-
セックスレスの既婚女性は自慰...
-
メルカリのメルカードで買い物...
-
RPGプログラムの*HIVALについて
-
リョウ・・・量?料?
おすすめ情報