sed-捕获一组并仅替换一个字符

问题描述

我有以下问题,文件的格式如下:

1XYZ00

结果将是

2XYZ00

我只想将第一个数字更改为另一个数字,例如9,而不更改其余样式。

我真的需要捕获此模式 1XYZ00 并且仅捕获此模式,然后将第一个数字替换为另一个。 该文件可以有数字,但可以使用不同的模式,因此不能修改。

操作系统是CentOS 7。

这是我测试过的

sed -E 's/1{1}[A-Z]{3}[0-9]{2}/9{1}[A-Z]{3}[0-9]{2}/g' ~/input.txt > ~/output.txt

我还尝试了捕获组:

sed --debug -E -r 's/1\(1{1}[A-Z]{3}[0-9]{2}\)/9\1/g' ~/input.txt > ~/output.txt

sed的调试模式告诉我模式匹配,但是没有替换。

我想我很亲密,请问有什么专家可以帮助我吗?

非常感谢

解决方法

$ cat ip.txt
foo 1XYZ00
xyz 1 2 3
hi 3XYZ00
1XYZ0A
cool 3ABC23

$ # matches any number followed by 3 uppercase and 2 digit characters
$ sed -E 's/[0-9]([A-Z]{3}[0-9]{2})/9\1/' ip.txt
foo 9XYZ00
xyz 1 2 3
hi 9XYZ00
1XYZ0A
cool 9ABC23

$ # matches digit '1' followed by 3 uppercase and 2 digit characters
$ sed -E 's/1([A-Z]{3}[0-9]{2})/9\1/' ip.txt
foo 9XYZ00
xyz 1 2 3
hi 3XYZ00
1XYZ0A
cool 3ABC23

关于OP的尝试:

  • 1{1}[A-Z]{3}[0-9]{2}1[A-Z]{3}[0-9]{2}
  • 在替换部分使用9{1}[A-Z]{3}[0-9]{2}将按字面值给您这些字符。它们没有任何特殊含义。
  • s/1\(1{1}[A-Z]{3}[0-9]{2}\)/9\1/确实使用捕获组,但()不应在激活-E选项的情况下进行转义,并且1{1}不应成为捕获组的一部分
,

我不确定这是否足以满足您的需求。

sed -i 's/1/9/' input.txt

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...