Tip: Other languages are Google-Translated. You can visit the English version of this link.
Log in


How to format a textbox as a percentage in Excel?

In the previous article, we have discussed a VBA method of formatting number in a textbox as currency in Excel. Here in this article, we are going to talk about formatting number in a textbox as a percentage in Excel with VBA method as well.

Format a textbox as percentage with VBA code

Format a textbox as percentage with VBA code

Please do as follows to format a textbox as a percentage with VBA code.

1. Click Developer > Insert > Text Box (ActiveX Control) to insert a textbox into worksheet. See screenshot:

2. Right-click the textbox, then click View Code from the context menu.

3. In the opening Microsoft Visual Basic for Applications window, please replace the original code in the Code window with below VBA code.

VBA code: format a textbox as percentage in Excel

Private Sub TextBox1_LostFocus()
    Dim xReg As New RegExp
    Dim xMatches As MatchCollection
    Dim xMatch As Match
    Dim xText As String
    Dim xReplace As String
    On Error Resume Next
    Application.ScreenUpdating = False
    xText = Me.TextBox1.Text
    xText = Replace(xText, "%", "")
    With xReg
        .Global = True
        .Pattern = "([^0-9]+\d+)|(\d{1,})"
        Set xMatches = .Execute(xText)
        For Each xMatch In xMatches
            xReplace = xReplace & xMatch.Value & "%"
    End With
    xText = xReplace & Mid(xText, Len(xReplace) - xMatches.Count + 1)
    Me.TextBox1.Text = xText
    Application.ScreenUpdating = True
End Sub

Note: Please change TextBox1 to the textbox name based on your need.

4. Click Tools > References. Then check the Microsoft VBScript Regular Expressions box in the References – VBAProject dialog box, and click the OK button. See screenshot:

5. Press the Alt + Q keys to exit the Microsoft Visual Basic for Applications window.

6. When it returns to the worksheet, please click Developer > Design Mode again to turn off the Design Mode.

From now on, when entering numbers into the textbox and shift the cursor out the textbox to click any cell, these numbers will be formatted as percentage automatically.

Related articles:

Recommended Productivity Tools for Excel

Kutools for Excel Helps You Always Finish Work Ahead of Time, and Stand Out From Crowd

  • More than 300 powerful advanced features, designed for 1500 work scenarios, increasing productivity by 70%, give you more time to take care of family and enjoy life.
  • No longer need memorizing formulas and VBA codes, give your brain a rest from now on.
  • Become an Excel expert in 3 minutes, Complicated and repeated operations can be done in seconds, 
  • Reduce thousands of keyboard & mouse operations every day, say goodbye to occupational diseases now.
  • 110,000 highly effective people and 300+ world-renowned companies' choice.
  • 60-day full features free trial. 60-day money back guarantees. 2 years of free upgrade and support.

Brings Tabbed Browsing and Editing to Microsoft Office, Far More Powerful Than The Browser's Tabs

  • Office Tab is designed for Word, Excel, PowerPoint and Other Office Applications: Publisher, Access, Visio and Project.
  • Open and create multiple documents in new tabs of the same window, rather than in new windows.
  • Increases your productivity by 50%, and reduces hundreds of mouse clicks for you every day!
Say something here...
symbols left.
You are guest ( Sign Up? )
or post as a guest, but your post won't be published automatically.
Loading comment... The comment will be refreshed after 00:00.

Be the first to comment.