عرفنا
8 September 2008, 02:25 AM
در این مقاله قسمتی از کدهای ارائه شده به وسیله ی مایکروسافت را معرفی می کنم که هر مقدار عددی قرار گرفته در یک سلول را به کلماتی انگلیسی (یا بنا بر سلیقه فارسی) تبدیل می کند.تمامی این مطالب برگرفته از مایکروسافت است. برای استفاده از این مقاله به مقداری اطلاعات excel نیاز دارید.در صورتی که به مشکل بر خوردید در همین تاپیک سوال بفرمایید.
این مقاله به شما نشان می دهد که چگونه تابعی ساده با نام ConvertCurrencyToEnglish() بسازید تا به وسیله ی آن مقادیر عددی را به کلمات معادل تبدیل کنید.برای نمونه اگر عدد 1234.56 را به تابع بدهید مقدار برگردانده شده One Thousand Two Hundred Thirty Four Dollars And Fifty Six Cents خواهد بود (در فارسی با دادن 1234،5 مقدار یک هزار دوست سی چهار تومان و 5 ریال)
از قسمت Function Wizard همچنین برای اضافه کردن تابع به worksheet می توان استفاده کرد.برای استفاده از Function Wizard مراحل زیر را طی کنید:
1.بر روی دگمه ی Function Wizard(دکمه ای شبیه به fx) کلیک کرده و از زیر مجموعه ی Function Category به User Defined بروید.
2. ConvertCurrencyToEnglish را انتخاب کرده و شماره ی مورد نظرتان یا سلول مرجعتان را وارد کنید.
3.بر روی Finish کلیک کنید.
برای ساختن تابع نمونه نیز این مراحل را انجام دهید:
1.به workbookتان یک module sheet اضافه کنید.برای انجام این عمل در اکسل 97 یا 98 به ماکرو رفته و سپس Visual Basic Editor را انتخاب کنید.در 2003 به Tools سپس ماکرو و بعد Visual Basic Editor برویدو ...(احتمال دارد در این مرحله به مشکل بر بخورید)
2.کدی که در ادامه می آید را وارد کنید:
Function ConvertCurrencyToEnglish (ByVal MyNumber)
Dim Temp
Dim Dollars, Cents
Dim DecimalPlace, Count
ReDim Place(9) As String
Place(2) = " Thousand "
Place(3) = " Million "
Place(4) = " Billion "
Place(5) = " Trillion "
' Convert MyNumber to a string, trimming extra spaces.
MyNumber = Trim(Str(MyNumber))
' Find decimal place.
DecimalPlace = InStr(MyNumber, ".")
' If we find decimal place...
If DecimalPlace > 0 Then
' Convert cents
Temp = Left(Mid(MyNumber, DecimalPlace + 1) & "00", 2)
Cents = ConvertTens(Temp)
' Strip off cents from remainder to convert.
MyNumber = Trim(Left(MyNumber, DecimalPlace - 1))
End If
Count = 1
Do While MyNumber <> ""
' Convert last 3 digits of MyNumber to English dollars.
Temp = ConvertHundreds(Right(MyNumber, 3))
If Temp <> "" Then Dollars = Temp & Place(Count) & Dollars
If Len(MyNumber) > 3 Then
' Remove last 3 converted digits from MyNumber.
MyNumber = Left(MyNumber, Len(MyNumber) - 3)
Else
MyNumber = ""
End If
Count = Count + 1
Loop
' Clean up dollars.
Select Case Dollars
Case ""
Dollars = "No Dollars"
Case "One"
Dollars = "One Dollar"
Case Else
Dollars = Dollars & " Dollars"
End Select
' Clean up cents.
Select Case Cents
Case ""
Cents = " And No Cents"
Case "One"
Cents = " And One Cent"
Case Else
Cents = " And " & Cents & " Cents"
End Select
ConvertCurrencyToEnglish = Dollars & Cents
End Function
Private Function ConvertHundreds (ByVal MyNumber)
Dim Result As String
' Exit if there is nothing to convert.
If Val(MyNumber) = 0 Then Exit Function
' Append leading zeros to number.
MyNumber = Right("000" & MyNumber, 3)
' Do we have a hundreds place digit to convert?
If Left(MyNumber, 1) <> "0" Then
Result = ConvertDigit(Left(MyNumber, 1)) & " Hundred "
End If
' Do we have a tens place digit to convert?
If Mid(MyNumber, 2, 1) <> "0" Then
Result = Result & ConvertTens(Mid(MyNumber, 2))
Else
' If not, then convert the ones place digit.
Result = Result & ConvertDigit(Mid(MyNumber, 3))
End If
ConvertHundreds = Trim(Result)
End Function
Private Function ConvertTens (ByVal MyTens)
Dim Result As String
' Is value between 10 and 19?
If Val(Left(MyTens, 1)) = 1 Then
Select Case Val(MyTens)
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
' .. otherwise it's between 20 and 99.
Select Case Val(Left(MyTens, 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
' Convert ones place digit.
Result = Result & ConvertDigit(Right(MyTens, 1))
End If
ConvertTens = Result
End Function
Private Function ConvertDigit (ByVal MyDigit)
Select Case Val(MyDigit)
Case 1: ConvertDigit = "One"
Case 2: ConvertDigit = "Two"
Case 3: ConvertDigit = "Three"
Case 4: ConvertDigit = "Four"
Case 5: ConvertDigit = "Five"
Case 6: ConvertDigit = "Six"
Case 7: ConvertDigit = "Seven"
Case 8: ConvertDigit = "Eight"
Case 9: ConvertDigit = "Nine"
Case Else: ConvertDigit = ""
End Select
End Functionموفق باشید :icon_cool
این مقاله به شما نشان می دهد که چگونه تابعی ساده با نام ConvertCurrencyToEnglish() بسازید تا به وسیله ی آن مقادیر عددی را به کلمات معادل تبدیل کنید.برای نمونه اگر عدد 1234.56 را به تابع بدهید مقدار برگردانده شده One Thousand Two Hundred Thirty Four Dollars And Fifty Six Cents خواهد بود (در فارسی با دادن 1234،5 مقدار یک هزار دوست سی چهار تومان و 5 ریال)
از قسمت Function Wizard همچنین برای اضافه کردن تابع به worksheet می توان استفاده کرد.برای استفاده از Function Wizard مراحل زیر را طی کنید:
1.بر روی دگمه ی Function Wizard(دکمه ای شبیه به fx) کلیک کرده و از زیر مجموعه ی Function Category به User Defined بروید.
2. ConvertCurrencyToEnglish را انتخاب کرده و شماره ی مورد نظرتان یا سلول مرجعتان را وارد کنید.
3.بر روی Finish کلیک کنید.
برای ساختن تابع نمونه نیز این مراحل را انجام دهید:
1.به workbookتان یک module sheet اضافه کنید.برای انجام این عمل در اکسل 97 یا 98 به ماکرو رفته و سپس Visual Basic Editor را انتخاب کنید.در 2003 به Tools سپس ماکرو و بعد Visual Basic Editor برویدو ...(احتمال دارد در این مرحله به مشکل بر بخورید)
2.کدی که در ادامه می آید را وارد کنید:
Function ConvertCurrencyToEnglish (ByVal MyNumber)
Dim Temp
Dim Dollars, Cents
Dim DecimalPlace, Count
ReDim Place(9) As String
Place(2) = " Thousand "
Place(3) = " Million "
Place(4) = " Billion "
Place(5) = " Trillion "
' Convert MyNumber to a string, trimming extra spaces.
MyNumber = Trim(Str(MyNumber))
' Find decimal place.
DecimalPlace = InStr(MyNumber, ".")
' If we find decimal place...
If DecimalPlace > 0 Then
' Convert cents
Temp = Left(Mid(MyNumber, DecimalPlace + 1) & "00", 2)
Cents = ConvertTens(Temp)
' Strip off cents from remainder to convert.
MyNumber = Trim(Left(MyNumber, DecimalPlace - 1))
End If
Count = 1
Do While MyNumber <> ""
' Convert last 3 digits of MyNumber to English dollars.
Temp = ConvertHundreds(Right(MyNumber, 3))
If Temp <> "" Then Dollars = Temp & Place(Count) & Dollars
If Len(MyNumber) > 3 Then
' Remove last 3 converted digits from MyNumber.
MyNumber = Left(MyNumber, Len(MyNumber) - 3)
Else
MyNumber = ""
End If
Count = Count + 1
Loop
' Clean up dollars.
Select Case Dollars
Case ""
Dollars = "No Dollars"
Case "One"
Dollars = "One Dollar"
Case Else
Dollars = Dollars & " Dollars"
End Select
' Clean up cents.
Select Case Cents
Case ""
Cents = " And No Cents"
Case "One"
Cents = " And One Cent"
Case Else
Cents = " And " & Cents & " Cents"
End Select
ConvertCurrencyToEnglish = Dollars & Cents
End Function
Private Function ConvertHundreds (ByVal MyNumber)
Dim Result As String
' Exit if there is nothing to convert.
If Val(MyNumber) = 0 Then Exit Function
' Append leading zeros to number.
MyNumber = Right("000" & MyNumber, 3)
' Do we have a hundreds place digit to convert?
If Left(MyNumber, 1) <> "0" Then
Result = ConvertDigit(Left(MyNumber, 1)) & " Hundred "
End If
' Do we have a tens place digit to convert?
If Mid(MyNumber, 2, 1) <> "0" Then
Result = Result & ConvertTens(Mid(MyNumber, 2))
Else
' If not, then convert the ones place digit.
Result = Result & ConvertDigit(Mid(MyNumber, 3))
End If
ConvertHundreds = Trim(Result)
End Function
Private Function ConvertTens (ByVal MyTens)
Dim Result As String
' Is value between 10 and 19?
If Val(Left(MyTens, 1)) = 1 Then
Select Case Val(MyTens)
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
' .. otherwise it's between 20 and 99.
Select Case Val(Left(MyTens, 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
' Convert ones place digit.
Result = Result & ConvertDigit(Right(MyTens, 1))
End If
ConvertTens = Result
End Function
Private Function ConvertDigit (ByVal MyDigit)
Select Case Val(MyDigit)
Case 1: ConvertDigit = "One"
Case 2: ConvertDigit = "Two"
Case 3: ConvertDigit = "Three"
Case 4: ConvertDigit = "Four"
Case 5: ConvertDigit = "Five"
Case 6: ConvertDigit = "Six"
Case 7: ConvertDigit = "Seven"
Case 8: ConvertDigit = "Eight"
Case 9: ConvertDigit = "Nine"
Case Else: ConvertDigit = ""
End Select
End Functionموفق باشید :icon_cool