ユーザーフォーム「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で質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「ご処理進めて頂きますようお...
-
エクセルで、日付を入力すると...
-
メルカリのメルカードで買い物...
-
月度は何て読みますか?
-
findは動くがfindnextがマクロ...
-
UMLでの例外処理
-
VBAでループ内で使う変数名を可...
-
switch の範囲指定
-
【Excel】特定の文字を含むセル...
-
DoEventsがやはり分からない
-
FFTの結果ついて
-
取り消し線が入った文字を削除...
-
Access チェックボックスでチェ...
-
Excel VBAにて2つの処理を同時...
-
2重のDo~Loopは?
-
Loadイベント中にほかのイベン...
-
お家デートをしててハグを長い...
-
インタラクティブの反対語は?
-
RPGプログラムの*HIVALについて
-
EXCEL VBA マクロ 実行する度に...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「ご処理進めて頂きますようお...
-
エクセルで、日付を入力すると...
-
VBAでループ内で使う変数名を可...
-
メルカリのメルカードで買い物...
-
【Excel】特定の文字を含むセル...
-
DoEventsがやはり分からない
-
プログラミング言語についてc++...
-
EXCEL VBA マクロ 実行する度に...
-
UMLでの例外処理
-
switch の範囲指定
-
FFTの結果ついて
-
お家デートをしててハグを長い...
-
VBの質問#if 0 then ってどう...
-
findは動くがfindnextがマクロ...
-
離散時間フーリエ変換について
-
VB.NET Excelを読み込んでDataT...
-
インタラクティブの反対語は?
-
月度は何て読みますか?
-
リョウ・・・量?料?
-
Do~Loopした回数をカウントしたい
おすすめ情報