ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 6324|回复: 4

[求助] WORD VBA 实现千位分隔符转

[复制链接]

TA的精华主题

TA的得分主题

发表于 2011-2-7 12:42 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
之前在EXCEL HOME 中看到的VBA千位分隔符转换,怎样才能实现,如:12456789 转成12,456,789.00 后面的.00,还有WORD 2007除了用VBA 实现,还有其它方法吗?谢谢!


'* +++++++++++++++++++++++++++++
'* Created By SHOUROU@ExcelHome 2008-1-24 17:40:17
'仅测试于System: Windows NT Word: 11.0 Language: 2052
'№ 0314^The Code CopyIn [ThisDocument-ThisDocument]^'
'* -----------------------------
'显式变量声明
Option Explicit
Sub StandardNumber()
'本代码旨在解决WORD中数据转化为千分位
'数据限定要求:-922,337,203,685,477.5808 到 922,337,203,685,477.5807
'转化结果1000以上数据以千分位计算,小数点右侧保留二位小数;1000以下数据不变
'"2008"不被转换,但如"2008."将被转换为"2,008","2008.0"将被转换为"2,008.0"
    Dim myRange As Range, i As Byte, myValue As Currency, myString As String
    On Error Resume Next    '忽略错误
    Application.ScreenUpdating = False   '关闭屏幕更新
    Selection.HomeKey wdStory
    Do
        With Selection.Find
            .ClearFormatting    '清除格式
            .Text = "[0-9.]{4,15}"    '4到15位数据
            .MatchWildcards = True    '使用通配符
            .Wrap = wdFindStop
            .Forward = True
            If .Execute = False Then Exit Do
            myString = Selection.Text
            If VBA.IsNumeric(myString) Then
                myValue = VBA.Val(myString)
                If Len(myString) > 4 Then
                    '转为千分位格式
                    If myValue >= 1000 Then
                        myString = VBA.Format(myValue, "Standard")
                        Selection.Text = Replace(myString, ".00", "")
                    End If
                End If
            End If
            Selection.MoveRight
        End With
    Loop
    '恢复屏幕更新
    Application.ScreenUpdating = True

'

End Sub

TA的精华主题

TA的得分主题

发表于 2011-2-7 12:50 | 显示全部楼层

回复 1楼 skychow 的帖子

可以通过设置单元格格式来实现

TA的精华主题

TA的得分主题

发表于 2011-2-7 14:15 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2011-2-7 17:56 | 显示全部楼层

回复 2楼 正弋老兵 的帖子

word 中不可以设置单元格吧?这个不明白,谢谢

TA的精华主题

TA的得分主题

发表于 2018-11-1 14:12 | 显示全部楼层
将Selection.Text = Replace(myString, ".00", "")修改为Selection.Text = Replace(myString, "###,###,###,###,###.00", "")即可。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2025-1-11 18:31 , Processed in 0.023227 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表