Auto completion in textbox

kelly mort

Well-known Member
Joined
Apr 10, 2017
Messages
2,169
Office Version
  1. 2016
Platform
  1. Windows
Hello all
I have a challenge here:
I want my textbox to behave in such a way that when I start to enter data in it, it should look at a range in a worksheet and then suggest words or names as I type the letters.

So say I have a name "Kelly" in that range, when I start to type "K" , it should suggest "Kelly" for me to make my work cooler.


I am stucked. I need bigger brains to pull me out. Thanks
Kelly
 

Excel Facts

When they said...
When they said you are going to "Excel at life", they meant you "will be doing Excel your whole life".
You need to use a Activex Combobox for this.

A Textbox will not work for this:
 
Upvote 0
Tell me where your list of values are you want to choose from.
Tell me where you want the value entered when you choose the value.

So we are going to load all the values you want to choose from into a Activex Combobox

Then if you have: "George is a nice guy" loaded into the Combobox

When you enter Geo into the combobox the value you see will jump to "George is a nice Guy"

Then I assume you want this value entered some other place.
Then when you click outside the combobox the value you choose will be entered where you want.

So for example you need to tell me:

The values I want loaded in the combobox to choose from are in the range("A1:A75") or something like this
 
Upvote 0
Oh okay it seems I am not clear a bit here:

I want the textbox behave as we have in Excel cells, that when you have entered say "This is very important." and you later start to enter in a new cell "Th " then it suggests the above sentence.


Is there a way to achieve that?

Thanks
 
Upvote 0
I told you before as far as I know there is no way to do that.
I gave you another option but you must not like that option.
 
Upvote 0
U can trial something like this with data in "A" of sheet1 and an activeX textbox on the ws (ie. sheet code)....
Code:
Option Explicit
Dim Flag As Boolean

Private Sub TextBox1_Change()
If TextBox1.Text = vbNullString Then
Flag = False
End If
If Not Flag Then
Call test
End If
End Sub

Sub test()
Dim Lastrow As Long, Cnt As Long
If TextBox1.Text <> vbNullString Then
Lastrow = Sheets("sheet1").Cells(Rows.Count, "A").End(xlUp).Row
For Cnt = 1 To Lastrow
If Left(Sheets("Sheet1").Range("A" & Cnt).Value, Len(TextBox1.Text)) = TextBox1.Text Then
If MsgBox(prompt:="Replace with: " & Sheets("Sheet1").Range("A" & Cnt).Value, _
                                   Buttons:=vbYesNo, Title:="REPLACE?") = vbYes Then
Flag = True
TextBox1.Text = Sheets("Sheet1").Range("A" & Cnt).Value
Exit Sub
End If
End If
Next Cnt
End If
Flag = False
End Sub
U didn't say what U want to do with the found word/sentence. I'm guessing put the textbox contents somewhere and reset the textbox. So an activeX command button on the ws
would put the contents in "B1"of sheet1 and reset the textbox. HTH. Dave
Code:
Private Sub CommandButton1_Click()
Sheets("Sheet1").Range("B" & 1).Value = TextBox1.Text
TextBox1.Text = vbNullString
End Sub
 
Upvote 0
U can trial something like this with data in "A" of sheet1 and an activeX textbox on the ws (ie. sheet code)....
Code:
Option Explicit
Dim Flag As Boolean

Private Sub TextBox1_Change()
If TextBox1.Text = vbNullString Then
Flag = False
End If
If Not Flag Then
Call test
End If
End Sub

Sub test()
Dim Lastrow As Long, Cnt As Long
If TextBox1.Text <> vbNullString Then
Lastrow = Sheets("sheet1").Cells(Rows.Count, "A").End(xlUp).Row
For Cnt = 1 To Lastrow
If Left(Sheets("Sheet1").Range("A" & Cnt).Value, Len(TextBox1.Text)) = TextBox1.Text Then
If MsgBox(prompt:="Replace with: " & Sheets("Sheet1").Range("A" & Cnt).Value, _
                                   Buttons:=vbYesNo, Title:="REPLACE?") = vbYes Then
Flag = True
TextBox1.Text = Sheets("Sheet1").Range("A" & Cnt).Value
Exit Sub
End If
End If
Next Cnt
End If
Flag = False
End Sub
U didn't say what U want to do with the found word/sentence. I'm guessing put the textbox contents somewhere and reset the textbox. So an activeX command button on the ws
would put the contents in "B1"of sheet1 and reset the textbox. HTH. Dave
Code:
Private Sub CommandButton1_Click()
Sheets("Sheet1").Range("B" & 1).Value = TextBox1.Text
TextBox1.Text = vbNullString
End Sub

Oh okay thanks very much for this. I love it.

But can we turn off the case sensitive?
 
Upvote 0
Thanks for posting your outcome. Dave
Code:
Sub test()
Dim Lastrow As Long, Cnt As Long
If TextBox1.Text <> vbNullString Then
Lastrow = Sheets("sheet1").Cells(Rows.Count, "A").End(xlUp).Row
For Cnt = 1 To Lastrow
If UCase(Left(Sheets("Sheet1").Range("A" & Cnt).Value, Len(TextBox1.Text))) = TextBox1.Text Or _
LCase(Left(Sheets("Sheet1").Range("A" & Cnt).Value, Len(TextBox1.Text))) = TextBox1.Text Then
If MsgBox(prompt:="Replace with: " & Sheets("Sheet1").Range("A" & Cnt).Value, _
                                   Buttons:=vbYesNo, Title:="REPLACE?") = vbYes Then
Flag = True
TextBox1.Text = Sheets("Sheet1").Range("A" & Cnt).Value
Exit Sub
End If
End If
Next Cnt
End If
Flag = False
End Sub
 
Upvote 0

Forum statistics

Threads
1,225,750
Messages
6,186,808
Members
453,373
Latest member
Ereha

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