经常用到的几个sed命令

最近写shell脚本,经常用到一些需求,现梳理一下。

 

现在,有一个o.sh,其文件内容如下:

[root@ser6-51 dandan]# cat o.sh

aaaa
bbbb
[mysqld]
ccc
ddd
[mysqla]
eee

 

1:在某行行尾添加内容

#在aaaa这一行最后添加hello这个字符串

#$表示行尾的意思

[root@ser6-51 dandan]# sed -i '/aaaa/s/$/hello/' o.sh

[root@ser6-51 dandan]# cat o.sh

aaaahello
bbbb
[mysqld]
ccc
ddd
[mysqla]
Eee
 

注意:如果要添加的字符串中包含特殊字符,需要用\进行转义。

比如:这里想在bbbb这一行后面添加:/usr/local/mysql

[root@ser6-51 dandan]# sed -i '/bbbb/s/$/\/usr\/local\/mysql/' o.sh

[root@ser6-51 dandan]# cat o.sh

aaaahello
bbbb/usr/local/mysql
[mysqld]
ccc
ddd
[mysqla]
eee


2:在某一行后面添加新行

 

#在ccc这一行后面添加一个新行hello(用\n表示换行)

[root@ser6-51 dandan]# sed -i '/ccc/s/$/\nhello/' o.sh

[root@ser6-51 dandan]# cat o.sh

aaaahello
bbbb/usr/local/mysql
[mysqld]
ccc
hello
ddd
[mysqla]
eee

 

3:往文件最后添加一行

#在文件末尾添加一行hello dandan

[root@ser6-51 dandan]# echo -e "hello dandan" >> o.sh

[root@ser6-51 dandan]# cat o.sh

aaaahello
bbbb/usr/local/mysql
[mysqld]
ccc
hello
ddd
[mysqla]
eee
hello dandan

 

4:删除某一行

将hello dandan那一行删除

  

aaaahello
bbbb/usr/local/mysql
[mysqld]
ccc
hello
ddd
[mysqla]
eee

[root@ser6-51 dandan]# sed -i '/hello dandan/d' o.sh

[root@ser6-51 dandan]# cat o.sh

如果对文件内容特别熟悉,特别有把握,可以这样:

[root@ser6-51 dandan]# sed -i '/^hello/d' o.sh

[root@ser6-51 dandan]# cat o.sh

aaaahello
bbbb/usr/local/mysql
[mysqld]
ccc
ddd
[mysqla]
eee

先定位到以hello开头的那一行,然后删除。

 

5:删除特定行的特定内容

 

#将这一行bbbb/usr/local/mysql的字符串/usr/local/mysql删除。

 

[root@ser6-51 dandan]# sed -i '/^bbbb/s/\/usr\/local\/mysql//' o.sh 

 

--注意:这里最后是两个//,否则报错。

[root@ser6-51 dandan]# cat o.sh

aaaahello
bbbb
[mysqld]
ccc
ddd
[mysqla]
eee


注意:sed命令单引号之间的内容都是以/开头和结尾的,切勿落掉了/.

 

6:替换特定行的特定内容

类似于5删除特定行的特定内容,只需要添加替换后的内容即可。

如:

[root@ser6-70 download]# cat a.sh
[mysqld]
datadir=/var/lib/mysql
eew
aa
e
hello
date

将datadir那一行的 /var/lib/mysql替换为/data/mysql/data

[root@ser6-70 download]#  sed -i '/^datadir/s/\/var\/lib\/mysql/\/data\/mysql\/data/' a.sh 
[root@ser6-70 download]# cat a.sh
[mysqld]
datadir=/data/mysql/data
eew
aa
e
hello
date


7:截取部分行到新文件

要切出从2012-02-09到2012-09-10的所有数据行,(假设你的日志文件以yyyy-MM-dd的日期格式开头)只需要:

 
 
sed -n '/^2012-02-09/,/^2012-09-10/p' whole.log > part.log


8:在首行添加内容

如:在首行添加use mysql;

sed -i '1i\use mysql;' t1.bak


 --待深入研究sed,到时再多做补充。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值