如何用 sed 捕获一个数字并替换另一个?

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)

我究竟做错了什么?

Sun*_*eep 5

要始终替换行中的第三个数字:

$ 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)

另外,在这种情况下你不需要awksed您也可以添加过滤器:

$ 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)