lea*_*ode 3 regex sed capture-group
在文本文件 test.txt 中有很多行文本,我想提取其中的单行匹配:
blabla 28.40.00 blabla
Run Code Online (Sandbox Code Playgroud)
我想将中间数字的第一位数字(在本例中为 4)替换为 3。也就是说,无论中间的数字是什么(40、41、52、63等),我都希望它被替换为以3开头的数字(40变成30,41变成31,52变成32,63变成33) ETC)。
以下行匹配中间的数字并将其替换为数字3:
cat test.txt |awk '/blabla/'|sed -E s_[[:digit:]][[:digit:]]_3_2
output: blabla 28.3.00 blabla
Run Code Online (Sandbox Code Playgroud)
但是当我只想替换第一个数字时,sed 不起作用:
cat test.txt |awk '/blabla/'|sed -E s_[[:digit:]]\([[:digit:]]\)1_3\1_2
output: blabla 28.40.00 blabla
Run Code Online (Sandbox Code Playgroud)
我究竟做错了什么?
要始终替换行中的第三个数字:
$ echo 'blabla 28.40.00 blabla' | sed 's/[0-9]/3/3'
blabla 28.30.00 blabla
Run Code Online (Sandbox Code Playgroud)
如果 之前的数字.超过 2 位,则有一种解决方法:
$ echo 'blabla 528.40.00 blabla' | sed 's/\.[0-9]/.3/'
blabla 528.30.00 blabla
Run Code Online (Sandbox Code Playgroud)
在第二次尝试中,您应该引用该命令并使用未转义的括号。1在捕获组之后你似乎还有一个额外的。
$ echo 'blabla 28.40.00 blabla' | sed -E 's_[[:digit:]]([[:digit:]])_3\1_2'
blabla 28.30.00 blabla
Run Code Online (Sandbox Code Playgroud)
另外,在这种情况下你不需要awk。sed您也可以添加过滤器:
$ echo 'blabla 28.40.00 blabla' | sed -E '/blabla/ s_[[:digit:]]([[:digit:]])_3\1_2'
blabla 28.30.00 blabla
Run Code Online (Sandbox Code Playgroud)