7

grep在 TextWrangler 上使用来查找这种类型的字符串:

4,600.00

我的正则表达式命令如下:

\d.\d{3}.\d{2}

这似乎正确地找到了字符串。我想将字符串替换4,600.004600.00我希望将数据保存在.csv文件中。如何从找到的每个数字中删除逗号?

4

3 回答 3

12

搜索:(\d{1,3}),(\d{1,3})\.(\d{1,2})

代替:\1\2.\3

在 TextWrangler 中工作。

于 2012-08-09T12:50:41.290 回答
1

awk oneliner:

awk  --re-interval  '{x=gensub(/([0-9]{1,3}),([0-9]{3}\.[0-9]{2})/,"\\1\\2","g");print x}' file

测试:

kent$  awk --version|head -1
GNU Awk 3.1.6

kent$  echo "foo,bar,blah,46,000.00,some,more"|awk --re-interval  '{x=gensub(/([0-9]{1,3}),([0-9]{3}\.[0-9]{2})/,"\\1\\2","g");print x}'
foo,bar,blah,46000.00,some,more
于 2012-08-09T11:48:32.140 回答
0

一种使用方式sed

sed -r 's/([0-9]{1,3}),([0-9]{3}\.[0-9]{2})/\1\2/g' file.txt

您可以添加-i标志以将更改直接写入文件。

于 2012-08-09T12:40:40.090 回答