Jun 23, 2011

Convert Number to Words in Microsoft Excel - INR Value to INR Amount

Friend if you want to convert your amount figure in words (INR value)
in microsoft excel just follow the below steps.
Example- 123456 = One Lac Twenty Three Thousand Four Hundred and
Fifty Six Only.
Just do one thing open Excel and press ALT+F11 and Click on Insert
Module, then copy paste this data into the visual basic sheet and save
as the excel file as MACRO ENABLED WORKBOOK.
LASTLY where you have convert the number into words just type the
formula as =ySpellRupees(Cell Reference)
You are done
-------------------------------------------------------------------------------------------------
The Visual basic program are as follows: (start copy from Function
ySpellRupees(ByVal MyNumber) to End Function)


Function ySpellRupees(ByVal MyNumber)
Dim Rupees, Paise, Temp
Dim DecimalPlace, Count
ReDim Place(9) As String
Place(2) = " Thousand "
Place(3) = " Lac "
Place(4) = " Crore "
Place(5) = " Arab " ' String representation of amount
MyNumber = Trim(Str(MyNumber)) ' Position of decimal place 0 if none
DecimalPlace = InStr(MyNumber, ".")
'Convert Paise and set MyNumber to Rupee amount
If DecimalPlace > 0 Then
Paise = GetTens(Left(Mid(MyNumber, DecimalPlace + 1) & "00", 2))
MyNumber = Trim(Left(MyNumber, DecimalPlace - 1))
End If
Count = 1
Do While MyNumber <> ""
If Count = 1 Then Temp = GetHundreds(Right(MyNumber, 3))
If Count > 1 Then Temp = GetHundreds(Right(MyNumber, 2))
If Temp <> "" Then Rupees = Temp & Place(Count) & Rupees
If Count = 1 And Len(MyNumber) > 3 Then
MyNumber = Left(MyNumber, Len(MyNumber) - 3)
Else
If Count > 1 And Len(MyNumber) > 2 Then
MyNumber = Left(MyNumber, Len(MyNumber) - 2)
Else
MyNumber = ""
End If
End If
Count = Count + 1
Loop
Select Case Rupees
Case ""
Rupees = " "
Case "One"
Rupees = "One Rupee Only"
Case Else
Rupees = Rupees & " Rupees Only"
End Select
Select Case Paise
Case ""
Paise = " "
Case "One"
Paise = " and One Paisa"
Case Else
Paise = " and " & Paise & " Paise Only"
End Select
ySpellRupees = Rupees & Paise
End Function
'*******************************************
' Converts a number from 100-999 into text *
'*******************************************
Function GetHundreds(ByVal MyNumber)
Dim Result As String
If Val(MyNumber) = 0 Then Exit Function
MyNumber = Right("000" & MyNumber, 3) 'Convert the hundreds place
If Mid(MyNumber, 1, 1) <> "0" Then
Result = GetDigit(Mid(MyNumber, 1, 1)) & " Hundred "
End If
'Convert the tens and ones place
If Mid(MyNumber, 2, 1) <> "0" Then
Result = Result & GetTens(Mid(MyNumber, 2))
Else
Result = Result & GetDigit(Mid(MyNumber, 3))
End If
GetHundreds = Result
End Function
'*********************************************
' Converts a number from 10 to 99 into text. *
'*********************************************
Function GetTens(TensText)
Dim Result As String
Result = "" 'null out the temporary function value
If Val(Left(TensText, 1)) = 1 Then ' If value between 10-19
Select Case Val(TensText)
Case 10: Result = "Ten"
Case 11: Result = "Eleven"
Case 12: Result = "Twelve"
Case 13: Result = "Thirteen"
Case 14: Result = "Fourteen"
Case 15: Result = "Fifteen"
Case 16: Result = "Sixteen"
Case 17: Result = "Seventeen"
Case 18: Result = "Eighteen"
Case 19: Result = "Nineteen"
Case Else
End Select
Else ' If value between 20-99
Select Case Val(Left(TensText, 1))
Case 2: Result = "Twenty "
Case 3: Result = "Thirty "
Case 4: Result = "Forty "
Case 5: Result = "Fifty "
Case 6: Result = "Sixty "
Case 7: Result = "Seventy "
Case 8: Result = "Eighty "
Case 9: Result = "Ninety "
Case Else
End Select
Result = Result & GetDigit _
(Right(TensText, 1)) 'Retrieve ones place
End If
GetTens = Result
End Function
'*******************************************
' Converts a number from 1 to 9 into text. *
'*******************************************
Function GetDigit(Digit)
Select Case Val(Digit)
Case 1: GetDigit = "One"
Case 2: GetDigit = "Two"
Case 3: GetDigit = "Three"
Case 4: GetDigit = "Four"
Case 5: GetDigit = "Five"
Case 6: GetDigit = "Six"
Case 7: GetDigit = "Seven"
Case 8: GetDigit = "Eight"
Case 9: GetDigit = "Nine"
Case Else: GetDigit = ""
End Select
End Function


Find our latest codes with addon program

6 comments:

  1. It's working. Thanks brother
    . Yogesh

    ReplyDelete
  2. thanks a lot keep-up this type of help. thanks again

    ReplyDelete
  3. excellent working thank you so much sir

    ReplyDelete
  4. Sir,

    How to get Rupees word before the Amount.

    ReplyDelete
    Replies
    1. In fcy amount we used to read cents ... only ,, similar words..

      but in INR words we basically used to use the given format only,,,
      if you still need a change please feel free to mark us a mail, we will do the needful.

      also please check the latest version of this program with addon

      Delete
  5. how to remove rupees word from the beginning ???

    ReplyDelete

Copyright © 2014 ModTheApp All Rights Reserved.
Like us @ Facebook And Google+ - Follow us @ Twitter