Linux Shell之sed命令

ed是一个很好的文件处理工具,本身是一个管道命令,主要是以行为单位进行处理,可以将数据行进行替换、删除、新增、选取等特定工作,下面先了解一下sed的用法

sed命令行格式为:

sed [选项] ‘命令’ 输入文本 

sed [选项] ‘命令’ 输入文本 

常用选项:


        
-n∶使用安静(silent)模式。在一般sed 的用法中,所有来自 STDIN的资料一般都会被列出到萤幕上。但如果加上 -n 参数后,则只有经过sed特殊处理的那一行(或者动作)才会被列出来。
       -e∶直接在指令列模式上进行 sed 的动作编辑;
       -f∶直接将 sed 的动作写在一个档案内, -f filename 则可以执行 filename 内的sed动作;
       -r∶sed 的动作支援的是延伸型正规表示法的语法。(预设是基础正规表示法语法)
       -i∶直接修改读取的档案内容,而不是由萤幕输出。
       


常用命令:


        a  ∶新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~
       c   ∶取代, c 的后面可以接字串,这些字串可以取代n1,n2 之间的行!
       d   ∶删除,因为是删除啊,所以 d后面通常不接任何咚咚;
        i   ∶插入, i的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
        p  ∶列印,亦即将某个选择的资料印出。通常 p 会与参数 sed-n 一起运作~
        s  ∶取代,可以直接进行取代的工作哩!通常这个 s的动作可以搭配正规表示法!例如 1,20s/old/new/g 就是啦!

举例:(假设我们有一文件名为ab)

      删除某行

     [root@localhost ruby] # sed '1d' ab  

      #删除第一行 

     [root@localhost ruby] # sed '$d' ab 

      #删除最后一行

     [root@localhost ruby] # sed '1,2d' ab

     #删除第一行到第二行

     [root@localhost ruby] # sed '2,$d' ab 

     #删除第二行到最后一行

   显示某行

.    [root@localhost ruby] # sed -n '1p' ab

      #显示第一行 

     [root@localhost ruby] # sed -n '$p' ab           

      #显示最后一行

     [root@localhost ruby] # sed -n '1,2p' ab       

     #显示第一行到第二行

     [root@localhost ruby] # sed -n '2,$p' ab

      #显示第二行到最后一行

  使用模式进行查询

     [root@localhost ruby] # sed -n '/ruby/p' ab

    #查询包括关键字ruby所在所有行

     [root@localhost ruby] # sed -n '/\$/p' ab

    #查询包括关键字$所在所有行,使用反斜线\屏蔽特殊含义

  增加一行或多行字符串

     [root@localhost ruby]# cat ab
     Hello!
     ruby is me,welcome to my blog.
     end
     [root@localhost ruby] # sed '1a drink tea' ab  

    #第一行后增加字符串"drink tea"

     Hello!
     drink tea
     ruby is me,welcome to my blog. 
     end
     [root@localhost ruby] # sed '1,3a drink tea' ab 

    #第一行到第三行后增加字符串"drink tea"
     Hello!
     drink tea
     ruby is me,welcome to my blog.
     drink tea
     end
     drink tea
     [root@localhost ruby] # sed '1a drink tea\nor coffee' ab 

   #第一行后增加多行,使用换行符\n
     Hello!
     drink tea
     or coffee
     ruby is me,welcome to my blog.
     end

  代替一行或多行

     [root@localhost ruby] # sed '1c Hi' ab                

    #第一行代替为Hi

     Hi
     ruby is me,welcome to my blog.
     end
     [root@localhost ruby] # sed '1,2c Hi' ab 

     #第一行到第二行代替为Hi

     Hi
     end

  替换一行中的某部分

  格式:sed 's/要替换的字符串/新的字符串/g'   (要替换的字符串可以用正则表达式)

     [root@localhost ruby] # sed -n '/ruby/p' ab | sed 's/ruby/bird/g'    #替换ruby为bird

   [root@localhost ruby] # sed -n '/ruby/p' ab | sed 's/ruby//g'  

    #删除ruby

     插入

     [root@localhost ruby] # sed -i '$a bye' ab

     #在文件ab中最后一行直接输入"bye"

     [root@localhost ruby]# cat ab
     Hello!
     ruby is me,welcome to my blog.
     end
     bye

sed命令和选项:

 

a\ 在当前行后添加一行或多行
c\ 用新文本替换当前行中的文本
d 删除行
i\ 在当前行之前插入文本
h 把模式空间的内容复制到暂存缓冲区
H 把模式空间的内容添加到缓冲区
g 取出暂存缓冲区的内容,将其复制到模式缓冲区
G 取出暂存缓冲区的内容,将其追加到模式缓冲区
l 列出非打印字符
p 打印行
n 读入下一行输入,并从下一条而不是第一条命令对其处理
q 结束或退出sed
r 从文件中读取输入行
! 对所选行以外的行应用所有命令
s 用一个字符串替换另外一个字符串

 

扫描二维码关注公众号,回复: 1500371 查看本文章

 

 

替换标志:

 

g 在行内进行全局替换
p 打印行
w 将行写入文件
x 交换暂存缓冲区和模式空间的内容
y 将字符转换成另外一个字符

 

 

sed例子:

 

打印:p命令

 

sed ‘/abc/p’ file

打印file中包含abc的行。默认情况sed把所有行都打印到屏幕,如果某行匹配到模式,则把该行另外再打印一遍

sed  -n ‘/abc/p’ file 和上面一样,只是去掉了sed的默认行为,只会打印匹配的行

 

 

删除:d命令

 

sed ‘3,$d’ file    删除从第3行到最后一行的内容。
sed ‘$d’ file 删除最后一行的内容
sed ‘/abc/d’ 删除包含abc的行。
sed ‘3d’ file 删除第三行的内容

 

 

替换:s命令

 

sed  ‘s/abc/def/g’ file 把行内的所有abc替换成def,如果没有g,则只替换行内的第一个abc
sed  -n ‘s/abc/def/p’ file 只打印发生替换的那些行
sed  ‘s/abc/&def/’ file 在所有的abc后面添加def(&表示匹配的内容)
sed  -n ‘s/abc/def/gp’ file 把所有的abc替换成def,并打印发生替换的那些行
sed  ‘s#abc#def#g’ file 把所有的abc替换成def,跟在替换s后面的字符就是查找串和 
替换串之间的分割字符,本例中试#

 

 

指定行的范围:逗号

 

sed  -n ‘/abc/,/def/p’ file 打印模式abc到def的行
sed  -n ‘5/,/def/p’ file 打印从第五行到包含def行之间的行。
sed /abd/,/def/s/aaa/bbb/g 修改从模式abc到模式def之间的行,把aaa替换成def

 

 

多重编辑-e

 

sed  -e ‘1,3d’ -e ‘s/abc/def/g’ file 删除1-3行,然后把其余行的abc替换成def

 

 

读文件:r命令

 

sed  ‘/abc/r newfile’ file 在包含abc的行后读入newfile的内容

 

 

写文件:w命令  

 

sed  ‘/abc/w newfile’ file 在包含abc的行写入newfile

 

 

追加:a命令     

 

sed  ‘/abc/a\def’ file 在包含abc的行后新起一行,写入def

 

 

插入:i命令     

 

sed  ‘/abc/i\def’ file 在包含abc的行前新起一行,写入def

 

 

修改:c命令   

 

sed  ‘/abc/c\def’ file 在包含abc的行替换成def,旧文本被覆盖

 

 

读取下一行:n命令  

 

sed  ‘/abc/{n ; s/aaa/bbb/g;}’ file 读取包含abc的行的下一行,替换aaa为bbb

 

 

转换:y命令       

 

sed  ‘y/abc/ABC’ file 将a替换成A,b替换成B,c替换成C(正则表达式元字符不起作用)

 

 

退出:q命令   

 

sed  ‘/abc/{ s/aaa/bbb/ ;q; }’ file 在某行包含了abc,把aaa替换成bbb,然后退出sed。

 

 

暂存和取用:h命令(把模式行存储到暂存缓冲区)和g(取出暂存缓冲区的行并覆盖模式缓冲区)G(取出临时缓冲区的行)命令 

 

h和g是复制行为(覆盖),H和G表示追加。    

sed  -e ‘/abc/h’  -e ‘$G’ file 包含abc的行通过h命令保存到暂存缓冲区,在第二条命令汇中,sed读到最后一行$时,G命令从暂存缓冲区中读取一行,追加到模式缓冲区的后面。即所有包含abc的行的最后一行被复制到文件末尾。
sed -e ‘/abc/{h; d;}’ 
      -e  ‘/def/{g; }’ file
包含abc的行会移到包含def的行上,并进行覆盖。

暂存和互换:h和x命令    


猜你喜欢

转载自blog.csdn.net/qq_33468857/article/details/80575466