Word VBA:对数字批量加千分位,设置小数位数和设置负数格式

该文章介绍了一个VBA宏函数,用于在Word文档中通过查找替换功能,结合FormatNumber函数自动格式化所有符合特定模式的数字。用户可以自定义小数位数、是否补零、负数处理方式和是否添加千分位。通过调用`数字格式替换程序入口`子程序,可以处理指定模式(如五位以上的数字)并显示替换计数。
摘要由CSDN通过智能技术生成

一、思路

用Word的查找替换方法【Find】查找位置,用FormatNumber生成对应数字的格式化字符串,依次替换。

二、代码

Function 数字格式替换(Optional 范围 As Range, Optional findText As String = "[0-9]{1,}", Optional 使用通配符 As Boolean = True, Optional 小数位数 As Long = -1, Optional 纯小数补零 As VbTriState = VbTriState.vbUseDefault, Optional 负数加括号 As VbTriState = VbTriState.vbUseDefault, Optional 加千分位 As VbTriState = VbTriState.vbUseDefault) As Long
    Dim pd As Boolean: pd = True
    Dim arr() As Range
    Dim i As Long: i = 0
    Dim s As String
    Dim r As String
    
    If fw Is Nothing Then
        pd = False
        Set fw = Selection.Range
        If fw.Start = fw.End Then
            Set fw = ActiveDocument.Range
        End If
    End If
    
    With fw.Find
        .ClearFormatting
        .Wrap = wdFindStop
        .Forward = True
        .MatchWildcards = 使用通配符
        .Text = findText
        Do While .Execute
            i = i + 1
            ReDim Preserve arr(1 To i)
            Set arr(i) = fw.Document.Range(fw.Start, fw.End)
            'arr(i).Select
            'Debug.Print fw.Text, fw.Start, fw.End
        Loop
    End With
    
    For i = UBound(arr) To LBound(arr) Step -1
        s = arr(i).Text
        r = s
        If IsNumeric(r) Then
            r = FormatNumber(s, 小数位数, 纯小数补零, 负数加括号, 加千分位)
        End If
        arr(i).Text = r
        'arr(i).Select
    Next i
    
    数字格式替换 = UBound(arr) - LBound(arr) + 1
    
    Erase arr
    If pd = False Then
        fw.Select
        Set fw = Nothing
    End If
End Function
Sub 数字格式替换程序入口()
    Dim i As Long
    i = 数字格式替换(findText:="[0-9]{5,}", 小数位数:=2)
    MsgBox "完成,共替换了" & i & "处数字格式。"
End Sub

三、执行

主程序

光标定位在主程序/程序入口范围内,点击【运行】即可。

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

VBA-守候

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值