如何使用正则表达式添加千位分隔符?

时间:2009-08-04 15:19:45

标签: regex formatting replace

我正在使用这个找到并替换的免费RegExp Designer。如何搜索所有数字并添加千位分隔符?

Input:      <node num='12345678'>
Output:     <node num='12,345,678'>

2 个答案:

答案 0 :(得分:7)

要仅在“num”属性值中重新格式化数字,您可以执行以下操作:

(?<=num='\d+)(?=(?:\d{3})+(?!\d))

但请注意,这只适用于.NET正则表达式,这是RegExp Designer使用的。大多数正则表达式都只允许与固定数量的字符匹配的lookbehinds。 Java正则表达式允许可变长度的lookbehinds,只要有明显的最大长度,所以你可以通过使用{min,max}量词最大化任意数字来伪造它:

(?<=num='\d{1,20})(?=(?:\d{3})+(?!\d))

John Hyland的正则表达式将适用于任何支持lookbehinds的风格。

编辑:我差点忘了;以下是没有外观的方法:

(num='\d{1,3}|\G\d{3})(?=(?:\d{3})+(?!\d))

出于纯粹的美学原因,我最喜欢这个。 :)

EDIT2:我忘了提到最后一个的替换字符串是"$1,"

答案 1 :(得分:5)

s/(?<=\d)(?=(\d\d\d)+(?!\d))/,/g

也就是说,如果你在某些时候使用除了字符串以外的任何其他数据,那么你正在使用的任何语言都可能具有格式化数字输出的功能。