linux sed命令替换特定字符之后的字符

如下文本:[root@justin home]# cat sed1.txt
1 3 2 3 4 5 5 6
3 1 3 2 4 3 6 7
3 1 3 2 3 4 5 6
4 1 3 3 2 5 5 3
需要替换2之后的3为9,而2之前的3不做替换,如何操作
[root@justin home]# sed -n '/2/ s/3/9/p' sed1.txt
1 9 2 3 4 5 5 6
9 1 3 2 4 3 6 7
9 1 3 2 3 4 5 6
4 1 9 3 2 5 5 3
[root@justin home]#

1、首先进入到Linux系统,分别创建两个目录vim1、vim2。

2、分别在vim1、vim2文件夹下创建两个测试文件file1.c、file2.c。

3、然后在file1.c中添加,如下内容。

4、在file2.c中添加如下内容,接下来将要批量将这两个文件中的len替换为size。

5、然后执行如下sed -i "s/len/size/g" `grep len -rl ./`。

6、执行上述命令后,分别再次打开上面新建立的两个文件,可以看到len已经被批量替换为了size。

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2018-01-07

最近写了几个小脚本用到了sed命令,学了一下,顺便记下


sed替换的基本语法为:

复制代码

代码如下:

sed 's/原字符串/替换字符串/'


单引号里面,s表示替换,三根斜线中间是替换的样式,特殊字符需要使用反斜线”\”进行转义,但是单引号”‘”是没有办法用反斜线”\”转义的,这时候只要把命令中的单引号改为双引号就行了,例如:

复制代码

代码如下:

sed "s/原字符串包含'/替换字符串包含'/" //要处理的字符包含单引号


命令中的三根斜线分隔符可以换成别的符号,这在要替换的内容有较多斜线是较为方便,只需要紧跟s定义即可,例如换成问号”?”:

复制代码

代码如下:

sed 's?原字符串?替换字符串?' //自定义分隔符为问号


可以在末尾加g替换每一个匹配的关键字,否则只替换每行的第一个,例如:

复制代码

代码如下:

sed 's/原字符串/替换字符串/' //替换所有匹配关键字


上箭头”^”表示行首,美元”$”符号如果在引号中表示行尾,但是在引号外却表示末行(最后一行),这里犯二了,搜了半天哪个符号表示首行,半天才想起来,首行就是数字”1″啊.那么在行首和行尾添加字符串就是把行尾和行首替换,例如:

复制代码

代码如下:

sed 's/^/添加的头部&/g' //在所有行首添加
sed 's/$/&添加的尾部/g' //在所有行末添加
sed '2s/原字符串/替换字符串/g' //替换第2行
sed '$s/原字符串/替换字符串/g' //替换最后一行
sed '2,5s/原字符串/替换字符串/g' //替换2到5行
sed '2,$s/原字符串/替换字符串/g' //替换2到最后一行


替换样式可以多个在同一条命令中执行,用分号”;”分隔,例如:

复制代码

代码如下:

sed 's/^/添加的头部&/g;s/$/&添加的尾部/g' //同时执行两个替换规则


sed处理过的输出是直接输出到屏幕上的,要保存可以将输出重定向,或者使用参数”i”直接在文件中替换:

复制代码

代码如下:

sed -i 's/原字符串/替换字符串/g' filename //替换文件中的所有匹配项

本回答被网友采纳
第2个回答  2013-12-20

你好,我试着写了如下的命令行,

是否能达到你的要求?

sed -n 's/\(.*2.*\)3\(.*\)/\19\2/p' sed1.txt

本回答被网友采纳
第3个回答  2013-12-20
如果匹配的是所有2后面的3的话可以用这个:sed 's/\(.*2.*\)3\(.*\)/\19\2/' sed1.txt
如果匹配的是2后面紧挨着的3的话可以用这个:sed 's/\(.*2.\)3\(.*\)/\19\2/' sed1.txt ,就是把.*2.*改成.*2. 因为*表示出现多次。
第4个回答  2017-09-25
sed "s/2 3/2 9/g" sed1.txt

看你的文本很简单,只需把2 3看成一组就可以了,而不是把3看成一组;
相似回答