如何解决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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。