我grep
在 TextWrangler 上使用来查找这种类型的字符串:
4,600.00
我的正则表达式命令如下:
\d.\d{3}.\d{2}
这似乎正确地找到了字符串。我想将字符串替换4,600.00
为4600.00
我希望将数据保存在.csv
文件中。如何从找到的每个数字中删除逗号?
搜索:(\d{1,3}),(\d{1,3})\.(\d{1,2})
代替:\1\2.\3
在 TextWrangler 中工作。
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
一种使用方式sed
:
sed -r 's/([0-9]{1,3}),([0-9]{3}\.[0-9]{2})/\1\2/g' file.txt
您可以添加-i
标志以将更改直接写入文件。