Excel VBAでユーザフォームのテキストボックスから取得したデータで、フィルタをかけることについて教えていただけないでしょうか。
下記のようなデータから、フォームに入力された文字列と部分一致するものを抽出したいと思っています。
A B C
1 aaa 555 ××株式会社
2 bbb 333 株式会社△△
3 ccc 123 □□センター
・
・
・
・
テキストボックスには複数のデータを入力するので、改行ごとに配列にして
1行ずつ探す、というところまではできたのですが
完全一致でしか検索することができません。
C列で探すときに、”株式会社”とフォームに入力すると、
1行目と2行目が抽出されるといったような形にしたいです。
ワイルドカードのようなものを使用して、
あいまい検索といいますか、配列にしたデータから部分一致で抽出をすることはできないのでしょうか?
現在、完全一致で抽出まではできたコードはこのような形です。
-------------------------
Private Sub CommandButton1_Click()
' 入力欄内のテキストを配列にして1行ずつ取得
Dim ArrayText
ArrayText = Split(入力欄.Text, vbCrLf)
' 入力欄空欄はエラー
If 入力欄 = "" Then
MsgBox "検索条件を入力してください。", vbExclamation, "入力エラー"
Exit Sub
End If
ActiveSheet.Range("A1:W1").AutoFilter field:=3, Criteria1:=ArrayText, _
Operator:=xlFilterValues
' 入力欄のクリア
入力欄 = ""
End Sub
-------------------------
いろいろ検索はしてみたのですが、アクセスばかりがヒットしてしまい…
VBAで実現するのは不可能なのでしょうか・・・?
まだまだ、VBA勉強しはじめなので根本的に違う部分等あるかもしれませんが、
どなたかご教授いただけないでしょうか。
宜しくお願い致します。
A 回答 (1件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:
こんばんは。
Criteria1:=ArrayText,
ArrayText は、そこに配列を入れて複数検索が可能ではあるのですが、ワイルドカードが使えたかどうか、あまりはっきりと記憶にありません。それ以外では、Operator:= xlOr で2個は可能ですが、それ以上はできないような気がします。それで、その代わりとしては、AdvancedFilter を使ってみました。
クライテリアは、Z1 に設けましたが、できるだけ、1行目から書く方法がよかったと思います。
それから、 .Range("A1:W1").CurrentRegion という部分は、多少問題が残るかと思います。きちんと、データと分かれていればよいのですが、そうでないと、別な所まで及んでしまいます。
細かい部分で抜けている所があるかもしれません。
'//
Private Sub CommandButton1_Click()
Dim i As Long, j As Long
Dim ArrayText
Dim ArrayText2
Dim CrRng As Range
With ActiveSheet
'クライテリアを消去
.Range("Z1").CurrentRegion.Columns(1).ClearContents
ArrayText = Split(入力欄.Text, vbCrLf)
'入力欄に何もない状態で、クリックすると、全体が現れる
If UBound(ArrayText) < 0 Then
If .FilterMode Then
.ShowAllData
End If
Exit Sub
End If
'貼り付けようの配列
ReDim ArrayText2(UBound(ArrayText), 0)
For i = 0 To UBound(ArrayText)
If ArrayText(i) <> "" Then
ArrayText2(j, 0) = "*" & ArrayText(i) & "*"
j = j + 1
End If
Next i
If j < 1 Then Exit Sub 'ArrayText2 の移行に失敗したら終了
'クライテリアをここで作る
.Range("Z1").Value = .Range("C1").Value
.Range("Z1").Offset(1).Resize(i + 1).Value = ArrayText2
Set CrRng = .Range("Z1").CurrentRegion.Resize(, 1)
'フィルターオプションで実行
.Range("A1:W1").CurrentRegion.AdvancedFilter _
Action:=xlFilterInPlace, _
CriteriaRange:=CrRng, _
Unique:=False
End With
'入力欄のクリア
入力欄.Text = ""
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBA Userformで一部別シートに転記がしたいのですが 2 2023/05/24 13:08
- Visual Basic(VBA) ユーザーフォーム「frm_基本❶」を立ち上げると新規で入力する行数を右下のNoとして表示しています。 1 2023/03/16 19:02
- Visual Basic(VBA) 列と行の名前(重複あり)が交差するセルに、データを入力したい 2 2022/06/25 22:42
- Visual Basic(VBA) 複数シートの複数列に入力されているデータを重複なしで抽出するVBAを作りたいです。 9 2022/06/17 10:33
- Excel(エクセル) 日付で矢印マクロ 4 2023/07/25 16:47
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
- Visual Basic(VBA) Excel VBA キーワードから列を取得して、さらに空欄行を非表示にする 3 2022/10/21 22:49
- Visual Basic(VBA) Sheet3から2つの条件でオートフィルターで抽出した個数をSheet2へ入力するマクロで、一つ目の 4 2023/01/12 23:40
- Visual Basic(VBA) 前回ご教授いただいたコードに覚えたてのループ処理で品名りんごAから順に20回for nextでループ 7 2023/01/13 22:01
- その他(Microsoft Office) Outlookメール 連絡先の検索について 〈 ご説明 〉 Windows PC の Outlook 1 2022/09/23 14:43
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教える店舗&オフィスのセキュリティ対策術
中・小規模の店舗やオフィスのセキュリティセキュリティ対策について、プロにどう対策すべきか 何を注意すべきかを教えていただきました!
-
ユーザーフォーム内のテキストボックスからオートフィルター抽出を行う方法
Visual Basic(VBA)
-
ユーザーフォームを表示中にシートの操作をさせるには
Excel(エクセル)
-
テキストボックス(VBA)でEnterを押したときに作動するマクロ
Access(アクセス)
-
-
4
コンボボックスの文字によるif文の作成
Visual Basic(VBA)
-
5
エクセルVBAで5行目からオートフィルタモードに設定したいたい
Excel(エクセル)
-
6
VBA フォームに入力された数値を検索条件としたい
Visual Basic(VBA)
-
7
Excelに埋め込んだVBAのプログラムが消えた。
その他(Microsoft Office)
-
8
【Excel VBA】ユーザーフォームで選択した複数条件に一致するデータ行を削除
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
数字以外の入力をエラーにする...
-
エクセルVBA テキストボックス...
-
テキストボックスの番号を使っ...
-
初歩的な事だと思います。 Sub...
-
入力フォームの値をQRコードで...
-
EXCEL VBA で指定した範囲に入...
-
DataGridView 列ごとの入力制限
-
c#でTextBoxの入力制限
-
エディットボックスの入力制限...
-
アクセスのマクロ
-
excel vba でユーザーフォーム...
-
TEXTAREA に入力時の位置
-
WebフォームのIMEモードを入力...
-
HTMLで入力値を半角大文字に制御
-
教えて!全角文字「μ」の半角
-
VBA R1C1形式で変数の入力について
-
VBAでInputBoxの再入力をさせる...
-
VBAの質問になります メッセー...
-
DataGridViewの桁数制限に関して
-
入力フォームへ、データを自動...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルVBA テキストボックス...
-
テキストボックスの番号を使っ...
-
初歩的な事だと思います。 Sub...
-
数字以外の入力をエラーにする...
-
EXCEL VBA で指定した範囲に入...
-
Excel-VBAでInputBox+Pulldown...
-
入力フォームの値をQRコードで...
-
VBAの質問になります メッセー...
-
c#でTextBoxの入力制限
-
VBAで質問があります
-
教えて!全角文字「μ」の半角
-
VBAでInputBoxの再入力をさせる...
-
excel vba でユーザーフォーム...
-
TextBoxから数字が文字...
-
エディットボックスの入力制限...
-
accessで該当するレコードがな...
-
DataGridViewの桁数制限に関して
-
VBA R1C1形式で変数の入力について
-
「イ分」・・・フンという文字...
-
Windowsのアプリ開発ってなんの...
おすすめ情報