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

如下文本:[root@justinhome]#catsed1.txt13234556313243673132345641332553需要替换2之后的3为9,而2之前的3不... 如下文本:[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]#
展开
 我来答
旅游路上小知识
高粉答主

2020-05-03 · 我是旅行小达人,专注解决旅行中遇到的问题
旅游路上小知识
采纳数:2 获赞数:83105

向TA提问 私信TA
展开全部

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 //替换文件中的所有匹配项

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
让服务成就美好生活
2013-12-20 · 让服务成就美好生活!
让服务成就美好生活
采纳数:1497 获赞数:2381

向TA提问 私信TA
展开全部

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

是否能达到你的要求?

sed -n 's/\(.*2.*\)3\(.*\)/\19\2/p' sed1.txt
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
爱交朋友啊
2013-12-20
知道答主
回答量:22
采纳率:0%
帮助的人:15.9万
展开全部
如果匹配的是所有2后面的3的话可以用这个:sed 's/\(.*2.*\)3\(.*\)/\19\2/' sed1.txt
如果匹配的是2后面紧挨着的3的话可以用这个:sed 's/\(.*2.\)3\(.*\)/\19\2/' sed1.txt ,就是把.*2.*改成.*2. 因为*表示出现多次。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友711eabb
2017-09-25 · TA获得超过709个赞
知道小有建树答主
回答量:727
采纳率:83%
帮助的人:324万
展开全部
sed "s/2 3/2 9/g" sed1.txt

看你的文本很简单,只需把2 3看成一组就可以了,而不是把3看成一组;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式