How to Convert Number to Words in Excel?

Initially, Microsoft Excel was developed to process large data arrays. However, it also created accounting records like invoices, evaluations, or balance sheets quickly and effectively.

In more or fewer payment documents, it is necessary to duplicate numeric values with their word form. Excel doesn’t have a default function that displays numbers as English words in a worksheet. Still, you can add this capability by pasting the following SpellNumber function code into a VBA (Visual Basic for Applications) module. This function lets you convert dollar and cent amount to words with a formula.

For example, 25.50 would read as Twenty Five Dollars and Fifty Cents. This can be very useful if you’re using Excel as a template to print checks. So what you need is not just convert numbers to words in Excel (123.45 to one hundred and twenty three, forty five), but spell out dollars and cents ($29.95 to twenty nine dollars and ninety nine cents), pounds and pence for GBP, Euros, and Eurocents for EUR, etc.

If you want to convert numeric values to text format without displaying them as words, use the TEXT function as an alternative.

Even Excel 2016 doesn’t have a built-in tool for spelling numbers, not to mention earlier versions. But that is when Excel is really good. You can always improve its functionality using formulas in all their combinations, VBA macros, or third-party add-ins.

How to Convert Number to Words in Excel

If you are looking for the number to text conversion, which means you want Excel to see your number as text, it’s a bit different. Usually, you need to change the cell format in Excel, do the following things:

  • Select your range with numbers.
  • Press Ctrl+1on the Number tab and select “Text” in the Category

How to Convert Numbers to Words Using SpellNumber VBA Macro

Microsoft didn’t want to add a tool for the number to words conversion. But they created and published the special VBA macro on their website.

You can find the macro mentioned as “spellnumber formula“. However, it is not a formula but a macro function or an Excel User-defined function (UDF).

The SpellNumber option can write dollars and cents. If you need a different currency, you can change “dollar” and “cent” with your choice. Below you will find a VBA code and follow the following steps, such as:

Step 1: Open the workbook where you need to spell the numbers into words.

Step 2: Press Alt + F11 to open the Visual Basic Editor window.

If you have several books opened, check that the needed workbook is active using the list of projects in the upper left corner of the editor, or one of the workbook elements is highlighted with blue.

Step 3: In the editor menu, go to the Insert tab and click on the Module button.

How to Convert Number to Words in Excel

Step 4: You will see a window named Module1. Please select all of the code in the frame below and paste it to this window.

  1. Option Explicit  
  2. ‘Main Function  
  3. Function SpellNumber(ByVal MyNumber)  
  4.     Dim Dollars, Cents, Temp  
  5.     Dim DecimalPlace, Count  
  6.     ReDim Place(9) As String  
  7.     Place(2) = ” Thousand ”  
  8.     Place(3) = ” Million ”  
  9.     Place(4) = ” Billion ”  
  10.     Place(5) = ” Trillion ”  
  11.    
  12.     MyNumber = Trim(Str(MyNumber))  
  13.     DecimalPlace = InStr(MyNumber, “.”)  
  14.     If DecimalPlace > 0 Then  
  15.         Cents = GetTens(Left(Mid(MyNumber, DecimalPlace + 1) & _  
  16.                   “00”, 2))  
  17.         MyNumber = Trim(Left(MyNumber, DecimalPlace – 1))  
  18.     End If  
  19.     Count = 1  
  20.     Do While MyNumber <> “”  
  21.         Temp = GetHundreds(Right(MyNumber, 3))  
  22.         If Temp <> “” Then Dollars = Temp & Place(Count) & Dollars  
  23.         If Len(MyNumber) > 3 Then  
  24.             MyNumber = Left(MyNumber, Len(MyNumber) – 3)  
  25.         Else  
  26.             MyNumber = “”  
  27.         End If  
  28.         Count = Count + 1  
  29.     Loop  
  30.     Select Case Dollars  
  31.         Case “”  
  32.             Dollars = “No Dollars”  
  33.         Case “One”  
  34.             Dollars = “One Dollar”  
  35.          Case Else  
  36.             Dollars = Dollars & ” Dollars”  
  37.     End Select  
  38.     Select Case Cents  
  39.         Case “”  
  40.             Cents = ” and No Cents”  
  41.         Case “One”  
  42.             Cents = ” and One Cent”  
  43.               Case Else  
  44.             Cents = ” and ” & Cents & ” Cents”  
  45.     End Select  
  46.     SpellNumber = Dollars & Cents  
  47. End Function  
  48.    
  49. Function GetHundreds(ByVal MyNumber)  
  50.     Dim Result As String  
  51.     If Val(MyNumber) = 0 Then Exit Function  
  52.     MyNumber = Right(“000” & MyNumber, 3)  
  53.     ‘ Convert the hundreds place.  
  54.     If Mid(MyNumber, 1, 1) <> “0” Then  
  55.         Result = GetDigit(Mid(MyNumber, 1, 1)) & ” Hundred ”  
  56.     End If  
  57.     ‘ Convert the tens and one’s place.  
  58.     If Mid(MyNumber, 2, 1) <> “0” Then  
  59.         Result = Result & GetTens(Mid(MyNumber, 2))  
  60.     Else  
  61.         Result = Result & GetDigit(Mid(MyNumber, 3))  
  62.     End If  
  63.     GetHundreds = Result  
  64. End Function  
  65.    
  66. Function GetTens(TensText)  
  67.     Dim Result As String  
  68.     Result = “” ‘ Null out the temporary function value.  
  69.     If Val(Left(TensText, 1)) = 1 Then   ‘ If value between 10-19…  
  70.         Select Case Val(TensText)  
  71.             Case 10: Result = “Ten”  
  72.             Case 11: Result = “Eleven”  
  73.             Case 12: Result = “Twelve”  
  74.             Case 13: Result = “Thirteen”  
  75.             Case 14: Result = “Fourteen”  
  76.             Case 15: Result = “Fifteen”  
  77.             Case 16: Result = “Sixteen”  
  78.             Case 17: Result = “Seventeen”  
  79.             Case 18: Result = “Eighteen”  
  80.             Case 19: Result = “Nineteen”  
  81.             Case Else  
  82.         End Select  
  83.     Else ‘ If value between 20-99…  
  84.         Select Case Val(Left(TensText, 1))  
  85.             Case 2: Result = “Twenty ”  
  86.             Case 3: Result = “Thirty ”  
  87.             Case 4: Result = “Forty ”  
  88.             Case 5: Result = “Fifty ”  
  89.             Case 6: Result = “Sixty ”  
  90.             Case 7: Result = “Seventy ”  
  91.             Case 8: Result = “Eighty ”  
  92.             Case 9: Result = “Ninety ”  
  93.             Case Else  
  94.         End Select  
  95.         Result = Result & GetDigit _  
  96.             (Right(TensText, 1))  ‘ Retrieve ones place.  
  97.     End If  
  98.     GetTens = Result  
  99. End Function  
  100.    
  101. Function GetDigit(Digit)  
  102.     Select Case Val(Digit)  
  103.         Case 1: GetDigit = “One”  
  104.         Case 2: GetDigit = “Two”  
  105.         Case 3: GetDigit = “Three”  
  106.         Case 4: GetDigit = “Four”  
  107.         Case 5: GetDigit = “Five”  
  108.         Case 6: GetDigit = “Six”  
  109.         Case 7: GetDigit = “Seven”  
  110.         Case 8: GetDigit = “Eight”  
  111.         Case 9: GetDigit = “Nine”  
  112.         Case Else: GetDigit = “”  
  113.     End Select  
  114. End Function  

Step 5: Press Ctrl + S to save the updated worksheet.

You will need to resave your workbook. When you try to save the workbook with a macro, you’ll get the message, “The following features cannot be saved in macro-free workbook“.

How to Convert Number to Words in Excel

Step 6: A VB project dialog box appears. Click on the No button.

Step 7: You can save your file as an Excel Macro-Enabled Workbook (.xlsm) to keep your file in its current format.

  • Click on the File tab.
  • Select the Save As option.
  • Click the Save as typedrop-down menu.
  • And in the save as type field, choose the “Excel macro-enabled workbook” file type.
How to Convert Number to Words in Excel

Step 8: And click on the Save button to save the file.

Disadvantages of Using Macro to SpellNumber in Excel

  • First, you must know VBA to modify the code according to your needs. It is necessary to paste the code for each workbook where you plan to change it. Otherwise, you will need to create a template file with macros and configure Excel to load this file at each start.
  • The main disadvantage of using a macro is if you send the workbook to somebody else, this person will not see the text unless the macro is built into the workbook. And even if it’s built-in, they will get an alert that there are macros in the workbook.

Leave a Comment

Your email address will not be published. Required fields are marked *