计算机教程

当前位置:3522.com > 计算机教程 > Linux的sed命令

Linux的sed命令

来源:http://www.4sports-uk.com 作者:3522.com 时间:2019-10-22 03:24

你可以用sed命令像文本处理器的查找替换功能一样,用一个字符串替换文件中的某个字符串。sed命令还可以从文件中删除连续的行。因为sed是一个流编辑器,它把给定的文件作为输入,将输出打印到屏幕,除非将输出重定向到一个文件。换句话说,sed不改变输入文件。

sed命令行格式为:

sed命令的一个形式如下:

         sed [-nefri]  ‘command’  输入文本/文件       

替换:sed 's///g'

 

删除:sed ',d'

常用选项:

我们先看下替换的例子。如果想把文件poem.txt中出现的所有lamb替换成ham,命令如下:

        -n∶取消默认的输出,使用安静(silent)模式。在一般 sed的用法中,所有来自 STDIN的资料一般都会被列出到屏幕上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来

cat poem.txt

        -e∶进行多项编辑,即对输入行应用多条sed命令时使用.直接在指令列模式上进行 sed 的动作编辑

Mary had a little lamb

        -f∶指定sed脚本的文件名. 直接将 sed 的动作写在一个档案内, -f filename 则可以执行 filename 内的sed 动作

Mary fried a lot of spam

        -r∶sed 的动作支援的是延伸型正则表达式的语法。(预设是基础正则表达式语法)

Jack ate a Spam sandwich

        -i∶直接修改读取的文件内容,而不是由屏幕输出     

Jill had a lamb spamwich

 

sed 's/lamb/ham/g' poem.txt

常用命令:

Mary had a little ham

        a ∶新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)

Mary fried a lot of spam

        c ∶取代, c 的后面可以接字串,这些字串可以取代n1,n2 之间的行

Jack ate a Spam sandwich

        d ∶删除,因为是删除,所以 d 后面通常不接任何内容

Jill had a ham spamwich

         i ∶插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行)

在单引号引起来的字符串中,"s"表示替换(substitute),"g"表示全局(global)替换。也可以去掉"g"(只替换每行第一次出现的字符串)或者指定一个数字(替换每行的前n次出现)。

         p∶列印,亦即将某个选择的资料印出。通常 p 会与参数sed -n 一起用

现在看一个保护删除行的例子。startend的值既可以是行号也可以是用以匹配的模式。从startend的所有行都从输出中移除。这个例子会删除从第2行开始,到并包含第3行的内容:

         s∶取代,可以直接进行替换的工作。通常这个 s 的动作可以搭配正则表达式。例如 1,20s/old/new/g

sed '2,3d' poem.txt

 

Mary had a little lamb

定址

Jill had a lamb spamwich

 

这个例子会删除从第1行开始,到包含Jack的哪一行的内容:

定址用于决定对哪些行进行编辑。地址的形式可以是数字、正则表达式、或二者的结合。如果没有指定地址,sed将处理输入文件的所有行。

sed '1,/Jack/d' poem.txt

地址是一个数字,则表示行号;是“$"符号,则表示最后一行。例如:

Jill had a lamb spamwich

sed -n '3p' datafile

sed命令的最常见用法是将一个文本字符串换成另一个文本字符串。事实上,sed用来查找和删除的字符串是正则表达式。这意味可以像grep那样使用模式匹配。虽然可能从来不会这么用,这里还是给出一个例子。将任何在行尾出现的lamb换成ham,并将结果存放在一个新文件中:

只打印第三行

sed 's/lamb$/ham/g' poem.txt > new.file

  只显示指定行范围的文件内容,例如:

因为将输出重定向到了一个文件,sed没有在屏幕上打印任何东西。查看新文件new.file,得到下面几行:

 

cat new.file

# 只查看文件的第100行到第200行

Mary had a little ham

sed -n '100,200p' mysql_slow_query.log

Mary fried a lot of spam

  地址是逗号分隔的,那么需要处理的地址是这两行之间的范围(包括这两行在内)。范围可以用数字、正则表达式、或二者的组合表示。例如:

Jack ate a Spam sandwich

 

Jill had a lamb spamwich

sed '2,5d' datafile

使用man sed命令来获取sed的更多信息。

#删除第二到第五行

3522.com 1

sed '/My/,/You/d' datafile

#删除包含"My"的行到包含"You"的行之间的行

sed '/My/,10d' datafile

#删除包含"My"的行到第十行的内容

 

 

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

     删除某行

     [3522.com,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 teanor 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

 

 

 

 替换:

 

-e是编辑命令,用于sed执行多个编辑任务的情况下。在下一行开始编辑前,所有的编辑动作将应用到模式缓冲区中的行上。

 

sed -e '1,10d' -e 's/My/Your/g' datafile

#选项-e用于进行多重编辑。第一重编辑删除第1-3行。第二重编辑将出现的所有My替换为Your。因为是逐行进行这两项编辑(即这两个命令都在模式空间的当前行上执行),所以编辑命令的顺序会影响结果。

 

# 替换两个或多个空格为一个空格

 

sed 's/[ ][ ]*/ /g' file_name

 

 

# 替换两个或多个空格为分隔符:

本文由3522.com发布于计算机教程,转载请注明出处:Linux的sed命令

关键词: 3522.com

上一篇:Ubuntu 11.10 上安装CUDA开发环境

下一篇:没有了