VBA初心者です。VBAでユーザーフォーム1を作成し、それぞれ「日報」というシートに張り付けることには成功しておりますが、「事業所名」を選択後、「管理番号」「施設名」のコンボボックスで検索、連動がうまくいきません。コンボボックス3「事業所名」で.AddItem "第1事業部".AddItem "第2事業部"他3事業所名と設定し、シート名「全施設」より、コンボボックス4「管理番号」(B2:B2000)で検索、同じくシート名「全施設」でコンボボックス5「施設名」(C2:C2000)を検索連動がうまくいきません。いろいろと検索して、設定しても思ったように出来ませんでした。アドバイスをよろしくお願い致します。
No.3ベストアンサー
- 回答日時:
No.2です。
細かい検証をしていませんでした。
コンボボックス4のコードを変更してください。
Private Sub ComboBox4_Change()
ComboBox5.Clear
Set myDic = CreateObject("Scripting.Dictionary")
With Worksheets("全施設")
lastRow = .Cells(Rows.Count, "A").End(xlUp).Row
myR = Range(.Cells(2, "A"), .Cells(lastRow, "C"))
For i = 1 To UBound(myR, 1)
If myR(i, 1) = ComboBox3 And myR(i, 2) = ComboBox4 Then
myStr = ComboBox3 & "_" & ComboBox4 & "_" & myR(i, 3)
If Not myDic.exists(myStr) Then
myDic.Add myStr, ""
End If
End If
Next i
End With
myKey = myDic.keys
For i = 0 To UBound(myKey)
myAry = Split(myKey(i), "_")
ComboBox5.AddItem myAry(2)
Next i
Set myDic = Nothing
End Sub
※ 前回のコードでは不要なものまで表示されてしまいました。
※ 前回書き忘れましたが、
コンボボックス3 → コンボボックス4 → コンボボックス5 の順での選択としています。
どうも失礼しました。m(_ _)m
ありがとうございます!思い通りに出来ました‼初心者の私に優しく対応してくださり本当に感謝いたします。またわからないことがありましたら、お力添えをお願いしたく思います。重ねてお礼申し上げます。
No.2
- 回答日時:
こんにちは!
コンボボックス3~5だけの処理で良いのですね。
一例です。
尚、お示しの上側の画像のようにコンボボックス3~5に表示するデータは「全施設」シートのA~C列にあるものとします。
Dim myDic As Object
Dim i As Long, lastRow As Long
Dim myStr As String
Dim myKey, myItem, myR, myAry
Private Sub UserForm_Initialize()
'//コンボボックス3~5以外の処理 ←すでに出来ているものとする//
'//▼ココから処理//
ComboBox3.Clear
ComboBox4.Clear
ComboBox5.Clear
Set myDic = CreateObject("Scripting.Dictionary")
With Worksheets("全施設")
lastRow = .Cells(Rows.Count, "A").End(xlUp).Row
myR = Range(.Cells(2, "A"), .Cells(lastRow, "A"))
For i = 1 To UBound(myR, 1)
If Not myDic.exists(myR(i, 1)) Then
myDic.Add myR(i, 1), ""
End If
Next i
End With
myKey = myDic.keys
For i = 0 To UBound(myKey)
ComboBox3.AddItem myKey(i)
Next i
Set myDic = Nothing
End Sub
Private Sub ComboBox3_Change()
ComboBox4.Clear
ComboBox5.Clear
Set myDic = CreateObject("Scripting.Dictionary")
With Worksheets("全施設")
lastRow = .Cells(Rows.Count, "A").End(xlUp).Row
myR = Range(.Cells(2, "A"), .Cells(lastRow, "B"))
For i = 1 To UBound(myR, 1)
If myR(i, 1) = ComboBox3 Then
If Not myDic.exists(myR(i, 2)) Then
myDic.Add myR(i, 2), ""
End If
End If
Next i
End With
myKey = myDic.keys
For i = 0 To UBound(myKey)
ComboBox4.AddItem myKey(i)
Next i
Set myDic = Nothing
End Sub
Private Sub ComboBox4_Change()
ComboBox5.Clear
Set myDic = CreateObject("Scripting.Dictionary")
With Worksheets("全施設")
lastRow = .Cells(Rows.Count, "A").End(xlUp).Row
myR = Range(.Cells(2, "A"), .Cells(lastRow, "C"))
For i = 1 To UBound(myR, 1)
myStr = myR(i, 1) & "_" & myR(i, 2) & "_" & myR(i, 3)
If Not myDic.exists(myStr) Then
myDic.Add myStr, ""
End If
Next i
End With
myKey = myDic.keys
For i = 0 To UBound(myKey)
myAry = Split(myKey(i), "_")
ComboBox5.AddItem myAry(2)
Next i
Set myDic = Nothing
End Sub
こんな感じでどうなりますか?m(_ _)m
No.1
- 回答日時:
まぁ15年位前からこのような質問はあって解説サイトも増えてきてますが、もしまだご覧になってないなら一度試されては?
Excel VBA 複数(3つ以上)のコンボボックスに連動するリストを登録する
https://officedic.com/excel-vba-howto-combobox-3 …
ご連絡ありがとうございます。お知らせくださいましたサイトは真っ先に見たのですが、自分で作成したテキスト1からコンボボックス2迄のコードにプラスしてどうしたら続けられるのか、初心者には考えが至らず皆様のお力添えにすがってしまいました。いきなり皆様にお伺いするのは失礼と思い、上記サイトの他もさんざん見て、試してみてやっぱりうまくいかず、最後の最後にお願いに参りました。自力で何とかしようとした事だけはご理解ください。また困ったことがありましたら、ご教示くださいますようお願い致します。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 2つ目のコンボボックスが動作しません。 3 2023/03/25 12:29
- Visual Basic(VBA) ユーザーフォーム「frm_基本❶」を立ち上げると新規で入力する行数を右下のNoとして表示しています。 1 2023/03/16 19:02
- Access(アクセス) Accessで予定表を作成しようとしてます。 テーブル フィールド名 連番 オートナンバー型 年月日 2 2023/07/23 11:40
- Access(アクセス) Accessフォーム 一部のレコードだけを抽出する方法について 1 2022/06/28 18:45
- Access(アクセス) Accessの参照フィールドの列がずれてしまいます 1 2023/07/19 15:00
- その他(データベース) Excel VBA 転記について 1 2022/04/20 16:55
- Excel(エクセル) VLOOKUP が機能しない、その原因は何 ? 8 2022/10/19 12:06
- Visual Basic(VBA) VBA 改行コードの取り方 1 2022/03/22 14:14
- SQL Server DBのテーブルの設計ができず困っています。 2 2023/06/29 16:43
- その他(プログラミング・Web制作) google formsを使ったタスク依頼フォーム作成におけるご相談 1 2023/06/22 15:55
このQ&Aを見た人はこんなQ&Aも見ています
-
とっておきの「夜食」教えて下さい
真夜中に小腹がすいたときにこっそり作るメニュー、こっそり家を抜け出して食べに行くお店… 人には言えない、けど自慢したい、そんなあなたの「とっておきの夜食」を教えて下さい。
-
人生最悪の忘れ物
今までの人生での「最悪の忘れ物」を教えてください。 私の「最悪の忘れ物」は「財布」です。
-
これ何て呼びますか Part2
あなたのお住いの地域で、これ、何て呼びますか?
-
許せない心理テスト
私は「あなたの目の前にケーキがあります。ろうそくは何本刺さっていますか」と言われ「12本」と答えたら「ろうそくの数はあなたが好きな人の数です」と言われ浮気者扱いされたことをいまだに根に持っています。
-
【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
【お題】 ・このサンタクロースは偽物だと気付いた理由とは?
-
UserForm1.Showでエラーになります。
工学
-
Excel 複数マスタからのコンボボックス連動
Excel(エクセル)
-
VBAコンボボックスで選択した値をシートに転記したい
Visual Basic(VBA)
-
-
4
エクセルのラベルの値(文字列)を垂直方向で中央揃えにするには?
Excel(エクセル)
-
5
コンボボックスの文字によるif文の作成
Visual Basic(VBA)
-
6
Excel VBA ユーザーフォーム1のコンボボックスに別ブックの値を反映させたいです。
Visual Basic(VBA)
-
7
エクセルVBA 別シートからのコンボボックス連動
Visual Basic(VBA)
-
8
ユーザーフォームのテキストボックスに前回入力した値を表示する Excel
Visual Basic(VBA)
-
9
VBA コンボボックスとテキストボックスを連結させたい
Visual Basic(VBA)
-
10
【VBA】【ユーザーフォーム_ListBox】オートフィルタで絞りこんだ値だけを取り出したい
Visual Basic(VBA)
-
11
コンボボックス3つを連動させたい
Visual Basic(VBA)
-
12
テキストボックスの番号を使ったFor~Next文について
Visual Basic(VBA)
-
13
エクセルVBA ユーザーフォームのTextBoxを日付にしたい
Excel(エクセル)
-
14
コンボボックスの中身を任意順で並べ替え VBA
Excel(エクセル)
-
15
ユーザーフォーム、コンボボックスで重複せず選択リストを表示させるには
Excel(エクセル)
-
16
ユーザーフォームのラベルに日付を表示させる方法があればお願いします。出来ればコード書いていただけると
Visual Basic(VBA)
-
17
Excel VBA 複数選択したリストボックスからテキストボックスに転記したいです。
Visual Basic(VBA)
-
18
ユーザーフォーム上に現在日時と時刻を表示させていますがフォームを実行すると時間が更新されません。それ
Visual Basic(VBA)
-
19
ユーザーフォームに別シートからデータを反映させたい。
Visual Basic(VBA)
-
20
エクセルVBAで、条件に一致するセルへ移動
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
子供を手放すには?
-
浄水場近くの物件
-
同じ施設にLOFTとPLAZAがあった...
-
デイサービスでのDVD鑑賞は著作...
-
施設名と法人名
-
福祉施設を建てたら地価 価値...
-
お礼状を書きたいのですが、施...
-
18歳未満の深夜外出について 静...
-
IABP インターナルトリガーに...
-
カイジに出てくる地下労働施設...
-
乳児院や児童福祉施設で保護し...
-
旅先ホテルの柔らかすぎるマッ...
-
運動音痴なのにすごいスポッチ...
-
NPO法人きずなの会についての質...
-
ユーザーフォーム 3つのコンボ...
-
単位を教えて下さい
-
自衛隊の庁隊舎とはなんですか?
-
親戚の家をタライ回しにされ、...
-
長文になります。 リゾートバイ...
-
施設を設けるって日本語は変で...
おすすめ情報
作成したユーザーフォームです。
日報の画像です。