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-2019 e 365; Supporta tutte le lingue; Facile distribuzione 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 > Referenzee quindi controllare il Microsoft Scripting Runtime 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
Osservazioni:: 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:
Osservazioni:: 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 Enter 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 ...
- Super Formula Bar (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-2019 e 365. Supporta tutte le lingue. Facile distribuzione 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 centinaia di clic del mouse ogni giorno!
