如何在 Excel 中將數值轉換為英文單詞
本文包含 Microsoft Visual Basic for Applications 函數示例,您可以使用這些函數將 Microsoft Excel 工作表單元格中的數值轉換為等效的英文單詞。
創建名為 SpellNumber 的示例函數
(01)啟動 Microsoft Excel-----按 Alt+F11 啟動 Visual Basic 編輯器-----在“插入”菜單上,單擊“模塊”
(02)在模塊表中鍵入下面的代碼
(03)Option Explicit'Main FunctionFunction SpellNumber(ByVal MyNumber)Dim Dollars, Cents, TempDim DecimalPlace, CountReDim Place(9) As StringPlace(2) = " Thousand "Place(3) = " Million "Place(4) = " Billion "Place(5) = " Trillion "' String representation of mber = Trim(Str(MyNumber))' Position of decimal place 0 if malPlace = InStr(MyNumber, ".")' Convert cents and set MyNumber to dollar DecimalPlace > 0 ThenCents = GetTens(Left(Mid(MyNumber, DecimalPlace + 1) & _ "00", 2))MyNumber = Trim(Left(MyNumber, DecimalPlace - 1))End IfCount = 1Do While MyNumber <> ""Temp = GetHundreds(Right(MyNumber, 3))If Temp <> "" Then Dollars = Temp & Place(Count) & DollarsIf Len(MyNumber) > 3 ThenMyNumber = Left(MyNumber, Len(MyNumber) - 3)ElseMyNumber = ""End IfCount = Count + 1LoopSelect Case DollarsCase ""Dollars = "No Dollars"Case "One"Dollars = "One Dollar"Case ElseDollars = Dollars & " Dollars"End SelectSelect Case CentsCase ""Cents = " and No Cents"Case "One"Cents = " and One Cent"Case ElseCents = " and " & Cents & " Cents"End SelectSpellNumber = Dollars & CentsEnd Function ' Converts a number from 100-999 into text Function GetHundreds(ByVal MyNumber)Dim Result As StringIf Val(MyNumber) = 0 Then Exit FunctionMyNumber = Right("000" & MyNumber, 3)' Convert the hundreds Mid(MyNumber, 1, 1) <> "0" ThenResult = GetDigit(Mid(MyNumber, 1, 1)) & " Hundred "End If' Convert the tens and ones Mid(MyNumber, 2, 1) <> "0" ThenResult = Result & GetTens(Mid(MyNumber, 2))ElseResult = Result & GetDigit(Mid(MyNumber, 3))End IfGetHundreds = ResultEnd Function ' Converts a number from 10 to 99 into text. Function GetTens(TensText)Dim Result As StringResult = "" ' Null out the temporary function Val(Left(TensText, 1)) = 1 Then ' If value between ct 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 ElseEnd SelectElse ' If value between ct 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 ElseEnd SelectResult = Result & GetDigit _(Right(TensText, 1)) ' Retrieve ones IfGetTens = ResultEnd 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 SelectEnd Function
(04)關閉即可
使用 SpellNumber 示例函數
(01)方法 1:直接輸入通過將下面的公式輸入單元格中,可以將 32.50 更改為“Thirty Two Dollars and Fifty Cents”:=SpellNumber(32.50)
(02)方法 2:單元格引用可以引用工作簿中的其他單元格。例如,在單元格 A1 中輸入數字 32.50,然後在另一單元格中鍵入下面的公式:=SpellNumber(A1)
(03)方法 3:插入函數Excel 2003:選擇所需的單元格。單擊“常用”工具欄中的“插入函數”。在“或選擇類別”下,單擊“用户定義”。在“選擇函數”列表中,單擊“SpellNumber”,然後單擊“確定”。輸入所需的數字或單元格引用,然後單擊“確定”。Excel 2007 和 2010:選擇所需的單元格。單擊“公式”功能區上的“插入函數”。在“或選擇類別”下,單擊“用户定義”。在“選擇函數”列表中,單擊“SpellNumber”,然後單擊“確定”。輸入所需的數字或單元格引用,然後單擊“確定”。
(04)如圖
-
公共場所衞生許可證辦理
依據《公共場所衞生管理條例》,應辦理衞生許可證的公共場所有:(一)賓館、飯館、旅店、招待所、車馬店、咖啡館、酒吧、茶座;(二)公共浴室、理髮店、美容店;(三)影劇院、錄像廳(室)、遊藝廳(室)、(歌)舞廳、音樂廳;(四)體育場(館)、游泳場(館)、公園;(五)展覽館、博物館、美術館、圖書館;(六...
-
蘋果Mac電腦如何快速返回桌面
windows系統電腦都有快捷鍵可以一鍵返回桌面,或者任務欄右下角都可以返回桌面,但蘋果mac電腦的快捷鍵或者用觸摸板滑動會麻煩一些。那麼有沒有一種最方便的方法,鼠標指針直接移到某個位置,就可以快速返回桌面呢操作方法(01)從啟動台中找到“系統偏好設置”,並打開;(02)選...
-
低壓電工實際操作,三相電機的正反轉控制
低壓電工實際操作的一項重要項目:三相電機的正反轉控制。想實現電機的正反轉,只需要對調三相電源的兩根線路就可以實現。這樣控制電路需要兩個交流接觸器來實現,電機的電源的相序切換。為了實現互鎖和將接觸器的常閉觸點串接到電路中。操作方法(01)看懂原理圖:分為主...
-
如何跳出舒適圈
人們這麼努力工作,就是為了生活過得舒適。所謂苦盡甘來,就是這個意思。不過,在實現大目標的過程中,每完成一個階段小目標,我們的生活就會改善一些,精神也會滿足一些,即生活暫時處於舒適狀態。那麼,留戀片刻後,如果再不及時跳出安樂窩,勇攀高峯,那就無異於温水煮娃。然而,就...