Userform listbox search

Urtek1

New Member
Joined
Jan 31, 2022
Messages
2
Office Version
  1. 365
Platform
  1. Windows
So I have a user form that has a combo box that filters the data with the codes
Private Sub Combobox1_change()
Me.ListBox1.Clear
For i = 2 To Application.WorksheetFunction.CountA(Sheet3.Range("D:D"))
If Sheet3.Cells(i, "D").Value = Me.ComboBox1.Value Then
Me.ListBox1.AddItem Sheet3.Cells(i, "A").Value
End If
Next i

End Sub


Private Sub userform_initialize()
Me.ComboBox1.List = Array("Vermeer 755", "2000-320", "2350-1320", "2300-323", "2300-423", "2300-823", "2300-1123", "2300-2023", "2500-1825", "2500-1325", "2500-925", "2450-2423")

End Sub
This code does the combobox list and makes a listbox list based on selection.



Now this code is on a textbox used to search the list for specific items

Sub Show_Product()

Me.ListBox1.Clear

For i = 2 To Application.WorksheetFunction.CountA(Sheet3.Range("A:A"))
If Me.TextBox1.Value = "" Then
Me.ListBox1.AddItem Sheet3.Range("A" & i).Value


Else
If VBA.InStr(UCase(Sheet3.Range("A" & i).Value), UCase(Me.TextBox1.Value)) > 0 Then
Me.ListBox1.AddItem Sheet3.Range("A" & i).Value
End If
End If
Next i

End Sub
Problem I'm having is that it brings up an unfiltered list meaning it brings up products of same name but for different equipment. Basically not searching just the list by the combobox but searching the whole sheet in general. How can I search just what was filtered from combobox.
 

Excel Facts

Square and cube roots
The =SQRT(25) is a square root. For a cube root, use =125^(1/3). For a fourth root, use =625^(1/4).
Hi and welcome to MrExcel.

Try the following code.
It will filter in the listbox the matches of the combobox and the textbox.
A button is not necessary. Just select a item from the combo and start typing in the textbox.

Put all the code in the userform:
VBA Code:
Option Explicit

Dim a As Variant

Private Sub Combobox1_change()
  Call FilterData
End Sub
Private Sub TextBox1_Change()
  Call FilterData
End Sub

Sub FilterData()
  Dim cmb As String, txt As String
  Dim b As Variant
  Dim i As Long, j As Long
 
  ReDim b(1 To UBound(a), 1 To 2)
  ListBox1.Clear
  For i = 1 To UBound(a)
    If ComboBox1.Value = "" Then cmb = a(i, 4) Else cmb = ComboBox1.Value
    If TextBox1.Value = "" Then txt = a(i, 1) Else txt = TextBox1.Value
    If a(i, 4) = ComboBox1.Value And LCase(a(i, 1)) Like LCase(txt) & "*" Then
      j = j + 1
      b(j, 1) = a(i, 1)
      b(j, 2) = a(i, 4)
    End If
  Next i
  If j > 0 Then ListBox1.List = b
End Sub

Private Sub userform_initialize()
  ComboBox1.List = Array("Vermeer 755", "2000-320", "2350-1320", "2300-323", "2300-423", _
    "2300-823", "2300-1123", "2300-2023", "2500-1825", "2500-1325", "2500-925", "2450-2423")
  ListBox1.ColumnCount = 2
  a = Sheet3.Range("A2", Sheet3.Range("D" & Rows.Count).End(3)).Value
End Sub
 
Upvote 0
Solution
Hi and welcome to MrExcel.

Try the following code.
It will filter in the listbox the matches of the combobox and the textbox.
A button is not necessary. Just select a item from the combo and start typing in the textbox.

Put all the code in the userform:
VBA Code:
Option Explicit

Dim a As Variant

Private Sub Combobox1_change()
  Call FilterData
End Sub
Private Sub TextBox1_Change()
  Call FilterData
End Sub

Sub FilterData()
  Dim cmb As String, txt As String
  Dim b As Variant
  Dim i As Long, j As Long
 
  ReDim b(1 To UBound(a), 1 To 2)
  ListBox1.Clear
  For i = 1 To UBound(a)
    If ComboBox1.Value = "" Then cmb = a(i, 4) Else cmb = ComboBox1.Value
    If TextBox1.Value = "" Then txt = a(i, 1) Else txt = TextBox1.Value
    If a(i, 4) = ComboBox1.Value And LCase(a(i, 1)) Like LCase(txt) & "*" Then
      j = j + 1
      b(j, 1) = a(i, 1)
      b(j, 2) = a(i, 4)
    End If
  Next i
  If j > 0 Then ListBox1.List = b
End Sub

Private Sub userform_initialize()
  ComboBox1.List = Array("Vermeer 755", "2000-320", "2350-1320", "2300-323", "2300-423", _
    "2300-823", "2300-1123", "2300-2023", "2500-1825", "2500-1325", "2500-925", "2450-2423")
  ListBox1.ColumnCount = 2
  a = Sheet3.Range("A2", Sheet3.Range("D" & Rows.Count).End(3)).Value
End Sub
Thank you so much. Worked perfectly.
 
Upvote 0
I'm glad to help you. Thanks for the feedback.
 
Upvote 0

Forum statistics

Threads
1,224,813
Messages
6,181,117
Members
453,021
Latest member
Justyna P

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top