Note: The other languages of the website are Google-translated. Back to English

How to allow only numbers to be input in text box?

In Excel, we can apply the Data Validation function to allow only numbers to be entered into cells, but, sometimes, I want only numbers to be typed into a textbox as well as in cells. How to accept only numbers in a textbox in Excel?

Divide a range of cells by a number with Paste Special function

arrow blue right bubble Divide a range of cells by a number with Paste Special function

The following VBA code can help you to enter numbers, period (.) and a negative sign only into a textbox, please do as this:

1. Create a textbox by clicking Developer > Insert > Text Box (ActiveX Control), and then draw a textbox as you need, see screenshot:

doc textbox only numbers 1

2. Then right click the textbox and select View Code from context menu to open the Microsoft Visual Basic for Applications window, and then replace the original code with the following VBA code into the blank module:

VBA code: Allow only numbers to be input into the textbox:

Private Sub TextBox1_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
    If KeyAscii > Asc("9") Or KeyAscii < Asc("0") Then
        If KeyAscii = Asc("-") Then
            If InStr(1, Me.TextBox1.Text, "-") > 0 Or _
               Me.TextBox1.SelStart > 0 Then KeyAscii = 0
        ElseIf KeyAscii = Asc(".") Then
            If InStr(1, Me.TextBox1.Text, ".") > 0 Then KeyAscii = 0
            KeyAscii = 0
        End If
    End If
End Sub

doc textbox only numbers 2

3. Then save and close the code window, and exit the Design Mode, now, only numbers, period symbol and negative sign can be entered into the textbox, see screenshot:

doc textbox only numbers 3

Related articles:

How to apply spell check in textbox?

How to change textbox color based on value in Excel?

How to insert picture into text box?

How to set a default value in a textbox?

The Best Office Productivity Tools

Kutools for Excel Solves Most of Your Problems, and Increases Your Productivity by 80%

  • Reuse: Quickly insert complex formulas, charts and anything that you have used before; Encrypt Cells with password; Create Mailing List and send emails...
  • Super Formula Bar (easily edit multiple lines of text and formula); Reading Layout (easily read and edit large numbers of cells); Paste to Filtered Range...
  • Merge Cells/Rows/Columns without losing Data; Split Cells Content; Combine Duplicate Rows/Columns... Prevent Duplicate Cells; Compare Ranges...
  • Select Duplicate or Unique Rows; Select Blank Rows (all cells are empty); Super Find and Fuzzy Find in Many Workbooks; Random Select...
  • Exact Copy Multiple Cells without changing formula reference; Auto Create References to Multiple Sheets; Insert Bullets, Check Boxes and more...
  • Extract Text, Add Text, Remove by Position, Remove Space; Create and Print Paging Subtotals; Convert Between Cells Content and Comments...
  • Super Filter (save and apply filter schemes to other sheets); Advanced Sort by month/week/day, frequency and more; Special Filter by bold, italic...
  • Combine Workbooks and WorkSheets; Merge Tables based on key columns; Split Data into Multiple Sheets; Batch Convert xls, xlsx and PDF...
  • More than 300 powerful features. Supports Office / Excel 2007-2021 and 365. Supports all languages. Easy deploying in your enterprise or organization. Full features 30-day free trial. 60-day money back guarantee.
kte tab 201905

Office Tab Brings Tabbed interface to Office, and Make Your Work Much Easier

  • Enable tabbed editing and reading in Word, Excel, PowerPoint, 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!
officetab bottom
Comments (3)
No ratings yet. Be the first to rate!
This comment was minimized by the moderator on the site
Worked perfect! The best solution for this issue! Thank you!
This comment was minimized by the moderator on the site
can you also please share how to put max value in the code?
This comment was minimized by the moderator on the site
Hello, marc
Sorry, I can't understand you, do you mean to limit a max value in the code?
Would you give your problem more detailed?
Thank you!
There are no comments posted here yet

Follow Us

Copyright © 2009 - | All rights reserved. Powered by ExtendOffice. | Sitemap
Microsoft and the Office logo are trademarks or registered trademarks of Microsoft Corporation in the United States and/or other countries.
Protected by Sectigo SSL