跳至主要内容

如何在 Excel 中快速将货币数字转换为大写?

Author: Sun Last Modified: 2025-05-08

在 Excel 中处理财务数据时,有时需要将货币数字转换为大写,例如支票金额的书写。遗憾的是,Excel 并未提供内置函数来实现此功能,但有两种有效的方法可以完成这一任务。本文将向您介绍这两种方法,帮助您根据需求选择最佳方案。

Example of currency numbers in Excel converted to words

使用 VBA 代码将货币数字转换为大写

使用 Kutools for Excel 将货币数字转换为大写 good idea3


使用 VBA 代码将货币数字转换为大写

在 Excel 中,除了使用 VBA,无法快速将数字转换为英文大写。

1. 按下“Alt + F11”键打开“Microsoft Visual Basic for Applications”窗口。

2. 点击“插入”>“模块”,并将以下 VBA 代码粘贴到新模块窗口中。

VBA:将货币数字转换为英文大写

Function SpellNumberToEnglish(ByVal pNumber)
'Updateby20131113
Dim Dollars, Cents
arr = Array("", "", " Thousand ", " Million ", " Billion ", " Trillion ")
pNumber = Trim(Str(pNumber))
xDecimal = InStr(pNumber, ".")
If xDecimal > 0 Then
    Cents = GetTens(Left(Mid(pNumber, xDecimal + 1) & "00", 2))
    pNumber = Trim(Left(pNumber, xDecimal - 1))
End If
xIndex = 1
Do While pNumber <> ""
    xHundred = ""
    xValue = Right(pNumber, 3)
    If Val(xValue) <> 0 Then
        xValue = Right("000" & xValue, 3)
        If Mid(xValue, 1, 1) <> "0" Then
            xHundred = GetDigit(Mid(xValue, 1, 1)) & " Hundred "
        End If
        If Mid(xValue, 2, 1) <> "0" Then
            xHundred = xHundred & GetTens(Mid(xValue, 2))
        Else
            xHundred = xHundred & GetDigit(Mid(xValue, 3))
        End If
    End If
    If xHundred <> "" Then
        Dollars = xHundred & arr(xIndex) & Dollars
    End If
    If Len(pNumber) > 3 Then
        pNumber = Left(pNumber, Len(pNumber) - 3)
    Else
        pNumber = ""
    End If
    xIndex = xIndex + 1
Loop
Select Case Dollars
    Case ""
        Dollars = "No Dollars"
    Case "One"
        Dollars = "One Dollar"
    Case Else
        Dollars = Dollars & " Dollars"
End Select
Select Case Cents
    Case ""
        Cents = " and No Cents"
    Case "One"
        Cents = " and One Cent"
    Case Else
        Cents = " and " & Cents & " Cents"
End Select
SpellNumberToEnglish = Dollars & Cents
End Function
Function GetTens(pTens)
Dim Result As String
Result = ""
If Val(Left(pTens, 1)) = 1 Then
    Select Case Val(pTens)
        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
Select Case Val(Left(pTens, 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(pTens, 1))
End If
GetTens = Result
End Function
Function GetDigit(pDigit)
Select Case Val(pDigit)
    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

3. 然后保存此代码并关闭窗口返回工作表,选择一个空白单元格输入公式:=SpellNumberToEnglish(A2)(A2 是货币数字),按 Enter 键,然后向下拖动填充柄以将此公式应用到所需单元格。请参见截图:

Example of using SpellNumberToEnglish formula to convert currency number to words in Excel
Arrow down
Example of currency numbers in Excel converted to words

使用便捷的“数字转大写”功能将货币数字转换为大写

对于不想使用 VBA 的用户,Kutools for Excel 提供了一种简单的一键式方法将数字转换为大写。“小写金额转大写”功能支持将数字转换为超过 40 种不同货币格式的大写,是财务报告和国际交易的理想解决方案。只需几次点击,用户即可将数值转换为包括美元、欧元、英镑、日元、人民币等在内的多种语言的完整格式货币文本,无需手动转换并减少错误。

Kutools for Excel 提供了超过 300 种高级功能,简化复杂任务,提升创造力与效率。 通过集成 AI 能力,Kutools 能够精准自动执行任务,让数据管理变得轻松简单。Kutools for Excel 的详细信息...         免费试用...

1. 选择货币数字,然后点击“Kutools”>“文本”>“小写金额转大写”。请参见截图:

Screenshot showing Numbers to Words option in Kutools Content menu in Excel

2. 在“小写金额转大写”对话框中,选择要使用的语言;这里我将从“语言”列表框中选择“英语”选项,请参见截图:

Screenshot showing Numbers to Currency Words dialog with English and Chinese options

3. 点击“确定”或“应用”。然后所选的货币数字将被转换为特定的货币大写形式。

Screenshot of currency numbers converted to English words using Kutools

📌 注意:在应用此“小写金额转大写”功能之前,您可以将货币数字复制并粘贴到另一个工作表中。

在 Excel 中将货币数字转换为大写可以通过使用 VBA 或 Kutools for Excel 来高效完成。通过实施这些方法中的任何一种,您可以自动化财务报告并消除手动输入错误。如果您有兴趣探索更多 Excel 技巧,我们的网站提供了数千个教程,帮助您掌握 Excel


演示:使用 Kutools for Excel 将货币数字转换为大写

 
Kutools for Excel:超过 300 种实用工具触手可及!永久免费享受 AI 功能!立即下载!

最佳办公效率工具

🤖 Kutools AI 助手:基于智能执行生成代码创建自定义公式分析数据并生成图表调用 Kutools 函数等功能,彻底改变数据分析方式…
热门功能查找、高亮或标记重复项 | 删除空行 | 合并不丢失数据的列或单元格 | 四舍五入 ...
高级 LOOKUP多条件 VLookup | 多值 VLookup | 多表查找 | 模糊查找 ....
高级下拉列表快速创建下拉列表 | 从属下拉列表 | 多选下拉列表 ....
列管理器添加指定数量的列 | 移动列 | 切换隐藏列的可见状态 | 比较区域和列 ...
精选功能网格聚焦 | 设计视图 | 增强编辑栏 | 工作簿与工作表管理器 | 资源库(自动文本) | 日期提取 | 合并数据 | 加密/解密单元格 | 按列表发送电子邮件 | 超级筛选 | 特殊筛选(筛选粗体/斜体/删除线...)...
排名前 15 的工具集12 种文本 工具添加文本删除特定字符等) | 50 多 种图表 类型甘特图等) | 40 多种实用 公式基于生日计算年龄等) | 19 种插入 工具插入二维码根据路径插入图片等) | 12 种转换 工具小写金额转大写汇率转换等) | 7 种合并与分割 工具高级合并行分割单元格等) | 还有更多...

使用 Kutools for Excel 提升您的 Excel 技能,体验前所未有的高效。 Kutools for Excel 提供超过 300 种高级功能来提高生产力并节省时间。 单击此处获取您最需要的功能...


Office Tab 将标签式界面引入 Office,让您的工作更加轻松

  • 在 Word、Excel、PowerPoint 中启用标签式编辑和阅读
  • 在同一窗口的新标签页中打开和创建多个文档,而不是在新窗口中进行操作。
  • 将您的生产力提升 50%,每天为您减少数百次鼠标点击!