高效而轻松的sed命令

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

sed命令的使用规则

命令格式如下:

sed [option] ‘command‘ input_file 

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

-n 使用安静(silent)模式,只列出经过sed特殊处理的那一行(或者动作)内容; -e 直接在指令列模式上进行 sed 的动作编辑; -f 直接将 sed 的动作写在一个文件内, -f filename 则可以执行filename内的sed命令; -r 让sed命令支持扩展的正则表达式(默认是基础正则表达式); -i 直接修改读取的文件内容,而不是由屏幕输出;

常用的命令有以下几种:

a \: 即append追加字符串,可将其后的字符加在所选择内容的后面 c \: 取代/替换字符串,可将其后内容替换至所选内容 d : 即delete删除,该命令会将当前选中的行删除 i \: 即insert插入字符串,可将其后内容插入至所选内容前 p : print即打印,该命令会打印当前选择的行到屏幕上 s : 替换,通常s命令的用法是这样的:1,2s/old/new/g,将old字符串替换成new字符串 

命令示例

假设有一个本地文件test.txt,文件内容如下:

[[email protected] ~]$ cat test.txt this is first line this is second line this is third line this is fourth line this fifth line happy everyday end 

本节将使用该文件详细演示每一个命令的用法。

a命令

[[email protected] ~]$ sed ‘1a \add one‘ test.txt this is first line add one this is secondline this is third line this is fourth line this is fifth line happy everyday end 

本例命令部分中的1表示第一行,同样的第二行写成2,第一行到第三行写成1,3,用$表示最后一行,比如2,$表示第二行到最后一行中间所有的行(包含第二行和最后一行)。
本例的作用是在第一行之后增加字符串”add one”,从输出可以看到具体效果。

[[email protected] ~]$ sed ‘1,$a \add one‘ test.txt this is first line add one this is second line add one this is third line add one this is fourth line add one this is fifth line add one happy everyday add one end add one 

本例表示在第一行和最后一行所有的行后面都加上”add one”字符串,从输出可以看到效果。

[[email protected] ~]$ sed ‘/first/a \add one‘ test.txt this is first line add one this is secondline this is third line this is fourth line this is fifth line happy everyday end 

本例表示在包含”first”字符串的行的后面加上字符串”add one”,从输出可以看到第一行包含first,所以第一行之后增加了”add one”

[[email protected] ~]$ sed ‘/^ha.*day$/a \add one‘ test.txt this is first line this is secondline this is third line this is fourth line this is fifth line happy everyday add one end 

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

i命令

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

c命令

[[email protected] ~]$ sed ‘$c \add one‘ test.txt this is first line this is secondline this is third line this is fourth line this is fifth line happy everyday add one 

本例表示将最后一行替换成字符串”add one”,从输出可以看到效果。

[[email protected] ~]$ sed ‘4,$c \add one‘ test.txt this is first line this is secondline this is third line add one 

本例将第四行到最后一行的内容替换成字符串”add one”。

[[email protected] ~]$ sed ‘/^ha.*day$/c \replace line‘ test.txt this is first line this is secondline this is third line this is fourth line this is fifth line replace line end 

本例将以ha开头,以day结尾的行替换成”replace line”。

d命令

[[email protected] ~]$ sed ‘/^ha.*day$/d‘ test.txt this isfirst line this issecond line this isthird line this isfourth line this isfifth line end 

本例删除以ha开头,以day结尾的行。

[[email protected] ~]$ sed ‘4,$d‘ test.txt thisis first line thisis second line thisis third line 

本例删除第四行到最后一行中的内容。

p命令

[[email protected] ~]$ sed -n ‘4,$p‘ test.txt thisis fourth line thisis fifth line happy everyday end 

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

[[email protected] ~]$ sed -n ‘/^ha.*day$/p‘ test.txt happy everyday 

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

s命令

实际运用中s命令式最常使用到的。

[[email protected] ~]$ sed ‘s/line/text/g‘ test.txt this isfirst text this issecond text this isthird text this isfourth text this isfifth text happy everyday end 

本例将文件中的所有line替换成text,最后的g是global的意思,也就是全局替换,如果不加g,则只会替换本行的第一个line。

[[email protected] ~]$ sed ‘/^ha.*day$/s/happy/very happy/g‘ test.txt this isfirst line this issecond line this isthird line this isfourth line this isfifth line very happy everyday end 

本例首先匹配以ha开始,以day结尾的行,本例中匹配到的行是”happy everyday”这样,然后再将该行中的happy替换成very happy。

[[email protected] ~]$ sed ‘s/\(.*\)line$/\1/g‘ test.txt thisis first thisis second thisis third thisis fourth thisis fifth happy everyday end 

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

[[email protected] ~]$ sed ‘s/\(.*\)is\(.*\)line/\1\2/g‘ test.txt this first this second this third this fourth this fifth happy everyday end 

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

本文转载自:http://www.linuxprobe.com/high-efficiency-and-easy-sed-command.html

更多Linux干货请访问:http://www.linuxprobe.com/

时间: 2024-08-12 11:13:41

高效而轻松的sed命令的相关文章

Linux Shell学习-sed命令详解

(1).sed介绍 Sed是流编辑器,stream editor,它是一个将一些列编辑命令作用于一批文本文件的理想工具. (2).sed工作原理 Sed是一个非交互式文本编辑器,它可以对文本文件和标准输入进行编辑,标准输入可以是来自键盘输入.文件重定向.字符串.变量,甚至来自管道的文本. Sed从文本的一个文本行或标准输入中读取数据,将其复制到缓冲区,然后读取命令行或脚本的第一个命令,对此命令要求的行号进行编辑,重复此过程,直到命令行或脚本中的所有命令都执行完毕. 相对于诸如vi等其他文本编辑器

shell文本过滤编程(九):sed命令

[版权声明:转载请保留出处:blog.csdn.net/gentleliu.Mail:shallnew at 163 dot com] sed和awk类似,是很重要的文本过滤工具. 调用sed和调用awk一样,有三种方式: 1. 在命令行键入命令: 2.将sed命令插入脚本文件,然后调用sed: 3. 将sed命令插入脚本文件,并使sed脚本可执行. 使用sed命令行格式为: sed [option] 'sed cmd' inputfile 使用sed脚本文件,格式为: sed [option]

Shell之sed命令

sed用于一次性处理所有的编辑任务,尤为高效,为用户节省了大量的时间,sed适用于以下三种场合: 1.编辑相对交互文本编辑器而言太大的文件: 2.编辑命令太复杂,在交互式文本编辑器中难以输入的情况: 3.对文件扫描一遍,但是需要执行多个编辑函数的情况: sed 只是对缓冲区中原始文件的副本进行编辑,并不编辑原始的文件.因此,如果需要保存改动内容,需要将输出重定向到另一个文件,可以使用下面格式的命令: sed  'sed命令'  input_file > result_file 该命令将sed 命

详解Shell脚本:sed命令工具 ,awk命令工具

-----------------------------概述----------------------------------- Linux文本处理工具(以下都是命令和工具,而且只是作为展示,不能作为修改动作) grep(过滤,但是不支持正则表达式)egrep(支持正则表达式)sed (行过滤)awk(列过滤) - 正则表达式概念 正则表达式:使用单个字符串来描述.匹配一系列符合某个句法规则的字符串 由普通字符与特殊字符组成,一般用在脚本编程.文本编辑器中,如php.python.she等,

学习笔记之sed命令使用

一.概述 1.  sed 全称为Stream Editor,就是行编辑器,意味着一次只处理一行文本,sed将被匹配到            的行放到自己特定的空间(通常称为模式空间)中进行编辑:然后再根据结果进行输出显示: 2.  在sed中还有一段空间称为保持空间,sed模式空间中的内容可以与保持空间的内容可以进            行自由互换,实际工作中用处很少,仅作参考: Sed工作流程如图 二.sed命令使用 sed [OPTION]... 'script' [input-file].

sed命令

文本处理三剑客: grep, egrep, fgrep:文本过滤器 sed:Stream EDitor,流编辑器,行     pattem space:模式空间.(基础)     hold space:保持空间 awk:文本格式化工具,报告生成器 语法 sed [OPTION]...  'script'  [input-file] ... script:     地址定界编辑命令         :%s/ 常用选项: -n:不输出模式空间中的内容至屏幕: -e script, --express

sed命令及vim的末行命令

sed:StreamEDitor,流编辑器,以行为单位对一个或多个文件进行编辑处理:每一次sed都会处理给定文件中的一行内容. 在sed处理文本时,将正在处理的当前行存储到临时的缓冲区中,称为"模式空间":用当前行去匹配给定的PATTERN,如果能匹配,则使用command编辑处理:如果不匹配,则默认输出至标准输出:然后继续处理下一行,直到文件的末尾. 默认情况下,sed的所有处理行为不会影响源文件的内容: 我们一般会使用sed命令来自动编辑一个或多个文件,简化对文件的循环操作: se

sed命令总结

在编写shell脚本的过程中,我们经常需要使用sed流编辑器和awk对文本文件进行处理. 什么是sed? sed是一种在线编辑器,它一次处理一行内容.sed是非交互式的编辑器.它不会修改文件,除非使用shell重定向来保存结构.默认情况下,所有的输出行都被打印到屏幕上. sed的处理过程是什么? sed编辑器逐行处理文件(或输入),并将结果发送到屏幕.具体过程如下:首先sed先把当前正在处理的行保存在一个临时缓存区中(也称为模式空间),然后处理临时缓冲区中的行,完成后把该行发送到屏幕上.sed每

linux sed命令详解

Linux环境:Ubuntu16.04 sed命令 http://www.cnblogs.com/ggjucheng/archive/2013/01/13/2856901.html http://blog.csdn.net/yiqingnian28/article/details/23133043 正则表达式 http://blog.csdn.net/wzzfeitian/article/details/8842371 sed -help 查看sed的用法 -n, --quiet, --sile