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

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

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

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

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

Q&A

解決済

1回答

468閲覧

【超初心者】エクセル VBA クラスの作り方

ppss

総合スコア40

VBA

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

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

0グッド

0クリップ

投稿2020/08/27 04:31

【超初心者】エクセル VBA クラスモジュールの使い方・作り方がわかりません

よく使用するコードを汎用型にする方法がわかりません。
クラスモジュールにどのように書けばよいのかわからずつまづいています。
初歩的な内容で申し訳ありませんが、書き方を教えて頂けないでしょうか?

以下が検討内容です。

【TextBox】に入力した文字が【ListBox】に存在したら、その項目を選択する

という処理をしたくて以下のようなコードを書いています。
このコードの内【TextBox】【ListBox】のナンバーが変化したコードをいっぱい書く必要があるので
以下のコードを汎用型(クラス?インスタンス?)にしたいと思っています。

例)【TextBox3】の部分がTextBox5 や TextBox10 になったりします。【ListBox】も同様です。

コード(VBA) Dim i As Integer If TextBox3.Text = "" Then Exit Sub For i = 0 To ListBox1.ListCount - 1 If InStr(ListBox1.List(i), TextBox3.Text) <> 0 Then ListBox1.Selected(i) = True End If Next i

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

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

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

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

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

m.ts10806

2020/08/27 04:36

「初心者アイコン」があるのでタイトルや本文に改めて書く必要はないかと思います
guest

回答1

0

ベストアンサー

それぐらいなら、ユーザー定義関数を作成すればいいのでは。

標準モジュールに

vba

1Public Function ListSelect(tarListbox As msForms.Listbox, srcTextbox As msForms.TextBox) As Boolean 2 Dim i As Integer 3 4 ListSelect = False 5 If srcTextbox.Text = "" Then Exit Function 6 With tarListbox 7 For i = 0 To .ListCount - 1 8 If InStr(.List(i), srcTextbox.Text) <> 0 Then 9 .Selected(i) = True 10 ListSelect = True 11 End If 12 Next i 13 End With 14End Function

使用例

vba

1 2 Call ListSelect(ListBox1, TextBox1) 3 4 '結果を確認したいとき 5 If ListSelect(ListBox1, TextBox2) = False Then 6 MsgBox "該当データはありません。" 7 End If

投稿2020/08/27 05:05

hatena19

総合スコア33790

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

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

ppss

2020/08/27 05:45

ご回答ありがとうございます。 実際のプログラムで使用させて頂いたところうまくいきました。 書いていただいたコードの内容をよく調べて今後応用させて頂きます。 ありがとうございました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問