linux sed命令替换特定字符之后的字符
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。
推荐于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 //替换文件中的所有匹配项
你好,我试着写了如下的命令行,
是否能达到你的要求?
sed -n 's/\(.*2.*\)3\(.*\)/\19\2/p' sed1.txt
如果匹配的是2后面紧挨着的3的话可以用这个:sed 's/\(.*2.\)3\(.*\)/\19\2/' sed1.txt ,就是把.*2.*改成.*2. 因为*表示出现多次。
看你的文本很简单,只需把2 3看成一组就可以了,而不是把3看成一组;