Come completare automaticamente una casella di testo durante la digitazione in Excel?
Per impostazione predefinita, Excel può ricordare ciò che hai inserito nelle celle del foglio di lavoro corrente e completare automaticamente questo contenuto la prossima volta quando digiti una lettera iniziale correlata in una nuova cella. Tuttavia, se desideri che tutti i contenuti che hai inserito nel foglio di lavoro vengano completati automaticamente in una casella di testo (controllo ActiveX), come potresti fare? Questo articolo fornirà un metodo VBA per aiutarti a completare automaticamente una casella di testo quando digiti una lettera iniziale all'interno.
Completa automaticamente una casella di testo durante la digitazione con codice VBA
- Riutilizza qualsiasi cosa: Aggiungi le formule, i grafici e qualsiasi altra cosa più usati o complessi ai tuoi preferiti e riutilizzali rapidamente in futuro.
- Più di 20 funzioni di testo: Estrai numero dalla stringa di testo; Estrai o rimuovi parte di testi; Converti numeri e valute in parole inglesi.
- Unisci strumenti: Più cartelle di lavoro e fogli in uno; Unisci più celle / righe / colonne senza perdere dati; Unisci righe duplicate e somma.
- Strumenti di divisione: Suddivisione dei dati in più fogli in base al valore; Una cartella di lavoro su più file Excel, PDF o CSV; Da una colonna a più colonne.
- Incolla Salto Righe nascoste / filtrate; Count And Sum di Background Color; Invia e-mail personalizzate a più destinatari in blocco.
- Super filtro: Crea schemi di filtri avanzati e applicali a qualsiasi foglio; Riordina per settimana, giorno, frequenza e altro; Filtro in grassetto, formule, commenti ...
- Più di 300 potenti funzionalità; Funziona con Office 2007-2021 e 365; Supporta tutte le lingue; Facile implementazione nella tua azienda o organizzazione.
Completa automaticamente una casella di testo durante la digitazione con codice VBA
Si prega di fare quanto segue per completare automaticamente una casella di testo quando si digita una lettera iniziale all'interno della casella di testo.
1. Inserire una casella di testo facendo clic Costruttori > inserire > Casella di testo (controllo ActiveX). Vedi screenshot:
2. Quindi fare clic su Costruttori > inserire > Casella di riepilogo (controllo ActiveX) per inserire una casella di riepilogo nel foglio di lavoro corrente. Vedi screenshot:
3. Fare clic con il pulsante destro del mouse sulla scheda del foglio, quindi fare clic su Visualizza codice dal menu contestuale come mostrato nell'immagine sottostante.
4. Nel Microsoft Visual Basic, Applications Edition finestra, copia e incolla sotto il codice VBA nella finestra del codice. Quindi fare clic su Strumenti > Riferimentie quindi controllare il Runtime di script Microsoft casella nella Riferimenti - VBAProject la finestra di dialogo. Vedi screenshot:
Codice VBA: completa automaticamente una casella di testo durante la digitazione
Dim xRg As Range
Dim xDic As New Dictionary
Private Sub ListBox1_DblClick(ByVal Cancel As MSForms.ReturnBoolean)
Me.TextBox1.Value = Me.ListBox1.Value
End Sub
Private Sub Worksheet_Change(ByVal Target As Range)
Dim xVal As String
On Error Resume Next
If IsNumeric(Target.Value) Then
xVal = Str(Target.Value)
Else
xVal = Target.Value
End If
If xVal <> "" Then
If Not xDic.Exists(xVal) Then
xDic.Add xVal, xVal
End If
End If
End Sub
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
Me.ListBox1.Visible = False
End Sub
Private Sub Worksheet_Activate()
Dim I As Long
Dim xStr As String
On Error Resume Next
If xRg Is Nothing Then
Set xRg = ActiveSheet.UsedRange
End If
Me.ListBox1.Visible = False
xDic.RemoveAll
With Me.ListBox1
For I = 1 To xRg.Count
xStr = xRg(I).Value
If xStr <> "" Then
.AddItem xStr
If Not xDic.Exists(xStr) Then
xDic.Add xStr, xStr
End If
End If
Next
End With
End Sub
Private Sub TextBox1_KeyUp(ByVal KeyCode As MSForms.ReturnInteger, ByVal Shift As Integer)
With Me.ListBox1
.Top = Me.TextBox1.Top
.Left = Me.TextBox1.Left + Me.TextBox1.Width
.Width = Me.TextBox1.Width
End With
TextBoxVal Me.TextBox1.Object
End Sub
Sub TextBoxVal(xTextBox As Variant)
Dim I As Long
Dim xStr As String
On Error Resume Next
Application.ScreenUpdating = False
If xRg Is Nothing Then Exit Sub
Me.ListBox1.Clear
xStr = xTextBox.Value
If xStr = "" Then
Me.ListBox1.Visible = False
Application.EnableEvents = True
Exit Sub
End If
For I = 0 To UBound(xDic.Items)
If Left(xDic.Items(I), Len(xStr)) = xStr Then
Me.ListBox1.AddItem xDic.Items(I)
End If
Next
Me.ListBox1.Visible = True
If Me.ListBox1.ListCount > 0 Then
With xTextBox
.Value = Me.ListBox1.List(0)
.SelStart = Len(xStr)
.SelLength = Len(Me.ListBox1.List(0))
End With
End If
Me.ListBox1.Activate
Me.ListBox1.Selected(0) = True
Application.ScreenUpdating = True
End Sub
Private Sub ListBox1_KeyDown(ByVal KeyCode As MSForms.ReturnInteger, ByVal Shift As Integer)
If KeyCode = 13 Then
Me.TextBox1.Value = Me.ListBox1.Value
End If
End Sub
Note:: Nel codice, ListBox1 e Casella di testo 1 sono il nome della casella di riepilogo e della casella di testo che hai inserito nel foglio di lavoro.
5. premi il altro + Q tasti per uscire da Microsoft Visual Basic, Applications Edition finestra.
6. Disattivare la modalità di progettazione facendo clic su Costruttori > Modalità di progettazione nel foglio di lavoro.
7. Ora passa a un altro foglio di lavoro e poi torna al foglio di lavoro precedente per abilitare il codice VBA.
Da ora in poi. Quando inserisci una lettera iniziale nella casella di testo, tutti i testi che iniziano con quella lettera che hai inserito nel foglio di lavoro verranno elencati all'interno della casella di riepilogo che si trova sul lato destro della casella di testo. Fare doppio clic su quello necessario per inserirlo nella casella di testo. Vedi screenshot:
Note:: Puoi usare il Up or giù tasto freccia per spostarsi tra tutti i testi di completamento automatico nella casella di riepilogo, quindi premere il tasto Entra tasto per inserire quello necessario nella casella di testo.
Articoli correlati:
- Come selezionare automaticamente il testo di una casella di testo quando è selezionata in Excel?
- Come cancellare il contenuto della casella di testo quando si fa clic in Excel?
- Come concatenare testi di più celle in una casella di testo in Excel?
- Come disabilitare la modifica nella casella di testo per impedire l'inserimento dell'utente in Excel?
- Come formattare una casella di testo come percentuale in Excel?
I migliori strumenti per la produttività in ufficio
Kutools per Excel risolve la maggior parte dei tuoi problemi e aumenta la tua produttività dell'80%
- Riutilizzo: Inserisci rapidamente formule complesse, grafici e tutto ciò che hai usato prima; Crittografa celle con password; Crea mailing list e invia email ...
- Bar Super Formula (modifica facilmente più righe di testo e formula); Layout di lettura (leggi e modifica facilmente un gran numero di celle); Incolla su intervallo filtrato...
- Unisci celle / righe / colonne senza perdere dati; Contenuto delle celle divise; Combina righe / colonne duplicate... Impedisci celle duplicate; Confronta intervalli...
- Seleziona Duplica o Unico Righe; Seleziona Righe vuote (tutte le celle sono vuote); Super Find e Fuzzy Find in molte cartelle di lavoro; Selezione casuale ...
- Copia esatta Più celle senza modificare il riferimento della formula; Riferimenti di creazione automatica a più fogli; Inserisci punti elenco, Caselle di controllo e altro ...
- Estrai testo, Aggiungi testo, Rimuovi per posizione, Rimuovi spazio; Creare e stampare totali parziali di paging; Converti contenuto e commenti tra celle...
- Super filtro (salva e applica schemi di filtri ad altri fogli); Ordinamento avanzato per mese / settimana / giorno, frequenza e altro; Filtro speciale in grassetto, corsivo ...
- Combina cartelle di lavoro e fogli di lavoro; Unisci tabelle in base a colonne chiave; Suddividi i dati in più fogli; Conversione in batch xls, xlsx e PDF...
- Più di 300 potenti funzionalità. Supporta Office/Excel 2007-2021 e 365. Supporta tutte le lingue. Facile implementazione nella tua azienda o organizzazione. Funzionalità complete Prova gratuita di 30 giorni. Garanzia di rimborso di 60 giorni.

Scheda Office porta l'interfaccia a schede a Office e semplifica notevolmente il lavoro
- Abilita la modifica e la lettura a schede in Word, Excel, PowerPoint, Publisher, Access, Visio e Project.
- Apri e crea più documenti in nuove schede della stessa finestra, piuttosto che in nuove finestre.
- Aumenta la produttività del 50% e riduce ogni giorno centinaia di clic del mouse!
