也想出现在这里? 联系我们

Linux下的sed命令使用详解

作者 : 小编 本文共4193个字,预计阅读时间需要11分钟 发布时间: 2022-10-31 共2.17K人阅读
也想出现在这里? 联系我们

sed是stream editor的简称,也就是流编辑器。它一次处理一行内容,处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”pattern space,接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存储输出。

使用语法sed命令的使用规则是这样的:

复制代码

代码如下:

sed [option] \’command\’ input_file

其中option是可选的,常用的option有如下几种:

-n 使用安静silent模式(想不通为什么不是-s)。在一般sed的用法中,所有来自stdin的内容一般都会被列出到屏幕上。但如果加上-n参数后,则只有经过sed特殊处理的那一行(或者动作)才会被列出来;-e 直接在指令列模式上进行 sed 的动作编辑;-f 直接将 sed 的动作写在一个文件内, -f filename 则可以执行filename内的sed命令;-r 让sed命令支持扩展的正则表达式(默认是基础正则表达式);-i 直接修改读取的文件内容,而不是由屏幕输出。

常用的命令有以下几种:

a \\:追加行append, a \\的后面跟上字符串s(多行字符串可以用\\n分隔),则会在当前选择的行的后面都加上字符串s;

c \\:取代/替换行change,c \\后面跟上字符串s(多行字符串可以用\\n分隔),则会将当前选中的行替换成字符串s;i \\:插入行insert,i \\后面跟上字符串s(多行字符串可以用\\n分隔),则会在当前选中的行的前面都插入字符串s;d:删除行delete,该命令会将当前选中的行删除;p:打印print,该命令会打印当前选择的行到屏幕上;s:替换字符串subs,通常s命令的用法是这样的:1,2s/old/new/g,将old字符串替换成new字符串命令示例假设有一个本地文件test.txt,文件内容如下:

复制代码

代码如下:

[qifuguang@winwill~]$ cat test.txt

this is first linethis is second linethis is third linethis is fourth linethis fifth linehappy everydayend本节将使用该文件详细演示每一个命令的用法。

a命令(追加行)例一

复制代码

代码如下:

[qifuguang@winwill~]$ sed \’1a \\add one\’ test.txt

this is first lineadd onethis is second linethis is third linethis is fourth linethis is fifth linehappy everydayend本例命令部分中的1表示第一行,同样的第二行写成2,第一行到第三行写成1,3,用$表示最后一行,比如2,$表示第二行到最后一行中间所有的行(包含第二行和最后一行)。

本例的作用是在第一行之后增加字符串”add one”,从输出可以看到具体效果。

例二

复制代码

代码如下:

[qifuguang@winwill~]$ sed \’1,$a \\add one\’ test.txt

this is first lineadd onethis is second lineadd onethis is third lineadd onethis is fourth lineadd onethis is fifth lineadd onehappy everydayadd oneendadd one本例表示在第一行和最后一行所有的行后面都加上”add one”字符串,从输出可以看到效果。

例三

复制代码

代码如下:

[qifuguang@winwill~]$ sed \’/first/a \\add one\’ test.txt

this is first lineadd onethis is second linethis is third linethis is fourth linethis is fifth linehappy everydayend本例表示在包含”first”字符串的行的后面加上字符串”add one”,从输出可以看到第一行包含first,所以第一行之后增加了”add one”

例四

复制代码

代码如下:

[qifuguang@winwill~]$ sed \’/^ha.*day$/a \\add one\’ test.txt

this is first linethis is second linethis is third linethis is fourth linethis is fifth linehappy everydayadd oneend本例使用正则表达式匹配行,^ha.*day$表示以ha开头,以day结尾的行,则可以匹配到文件的”happy everyday”这样,所以在该行后面增加了”add one”字符串。

i命令(插入行)i命令使用方法和a命令一样的,只不过是在匹配的行的前面插入字符串,所以直接将上面a命令的示例的a替换成i即可,在此就不啰嗦了。

c命令(替换行)例五

复制代码

代码如下:

[qifuguang@winwill~]$ sed \’$c \\add one\’ test.txt

this is first linethis is second linethis is third linethis is fourth linethis is fifth linehappy everydayadd one本例表示将最后一行替换成字符串”add one”,从输出可以看到效果。

例六

复制代码

代码如下:

[qifuguang@winwill~]$ sed \’4,$c \\add one\’ test.txt

this is first linethis is second linethis is third lineadd one本例将第四行到最后一行的内容替换成字符串”add one”。

例七

复制代码

代码如下:

[qifuguang@winwill~]$ sed \’/^ha.*day$/c \\replace line\’ test.txt

this is first linethis is second linethis is third linethis is fourth linethis is fifth linereplace lineend本例将以ha开头,以day结尾的行替换成”replace line”。

d命令(删除行)例八

复制代码

代码如下:

[qifuguang@winwill~]$ sed \’/^ha.*day$/d\’ test.txt

this is first linethis is second linethis is third linethis is fourth linethis is fifth lineend本例删除以ha开头,以day结尾的行。

例九

复制代码

代码如下:

[qifuguang@winwill~]$ sed \’4,$d\’ test.txt

this is first linethis is second linethis is third line本例删除第四行到最后一行中的内容。

p命令(打印行)例十

复制代码

代码如下:

[qifuguang@winwill~]$ sed -n \’4,$p\’ test.txt

this is fourth linethis is fifth linehappy everydayend本例在屏幕上打印第四行到最后一行的内容,p命令一般和-n选项一起使用。

例十一

复制代码

代码如下:

[qifuguang@winwill~]$ sed -n \’/^ha.*day$/p\’ test.txt

happy everyday本例打印以ha开始,以day结尾的行。

s命令(替换字符串)实际运用中s命令式最常使用到的。

例十二

复制代码

代码如下:

[qifuguang@winwill~]$ sed \’s/line/text/g\’ test.txt

this is first textthis is second textthis is third textthis is fourth textthis is fifth texthappy everydayend本例将文件中的所有line替换成text,最后的g是global的意思,也就是全局替换,如果不加g,则只会替换本行的第一个line。

例十三

复制代码

代码如下:

[qifuguang@winwill~]$ sed \’/^ha.*day$/s/happy/very happy/g\’ test.txt

this is first linethis is second linethis is third linethis is fourth linethis is fifth linevery happy everydayend本例首先匹配以ha开始,以day结尾的行,本例中匹配到的行是”happy everyday”这样,然后再将该行中的happy替换成very happy。

例十四

复制代码

代码如下:

[qifuguang@winwill~]$ sed \’s/\\(.*\\)line$/\\1/g\’ test.txt

this is firstthis is secondthis is thirdthis is fourththis is fifthhappy everydayend这个例子有点复杂,先分解一下。首先s命令的模式是s/old/new/g这样的,所以本例的old部分即\\(.*\\)line$,sed命令中使用\\(\\)包裹的内容表示正则表达式的第n部分,序号从1开始计算,本例中只有一个\\(\\)所以\\(.*\\)表示正则表达式的第一部分,这部分匹配任意字符串,所以\\(.*\\)line$匹配的就是以line结尾的任何行。然后将匹配到的行替换成正则表达式的第一部分(本例中相当于删除line部分),使用\\1表示匹配到的第一部分,同样\\2表示第二部分,\\3表示第三部分,可以依次这样引用。比如下面的例子:

复制代码

代码如下:

[qifuguang@winwill~]$ sed \’s/\\(.*\\)is\\(.*\\)line/\\1\\2/g\’ test.txt

this firstthis secondthis thirdthis fourththis fifthhappy everydayend正则表达式中is两边的部分可以用\\1和\\2表示,该例子的作用其实就是删除中间部分的is。

1. 本站所提供的源码模板(主题/插件)等资源仅供学习交流,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担,有部分资源为网上收集或仿制而来,若模板侵犯了您的合法权益,请来信通知我们(Email: rayer@88.com),我们会及时删除,给您带来的不便,我们深表歉意!
2. 分享目的仅供大家学习和交流,请不要用于商业用途!
3. 如果你也有好源码或者教程,可以到用户中心发布投稿,分享有金币奖励和额外收入!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务 请大家谅解!
5. 如有链接无法下载、失效或广告,请联系站长,可领回失去的金币,并额外有奖!
6. 如遇到加密压缩包,默认解压密码为"www.zyfx8.cn",如遇到无法解压的请联系管理员!
本站部分文章、资源来自互联网,版权归原作者及网站所有,如果侵犯了您的权利,请及时联系我站删除。免责声明
资源分享吧 » Linux下的sed命令使用详解

常见问题FAQ

免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
织梦模板使用说明
你下载的织梦模板并不包括DedeCMS使用授权,根据DedeCMS授权协议,除个人非盈利站点外,均需购买DedeCMS商业使用授权。购买地址: http://www.desdev.cn/service-dedecms.html

发表评论

Copyright 2015-2020 版权所有 资源分享吧 Rights Reserved. 蜀ICP备14022927号-1
开通VIP 享更多特权,建议使用QQ登录