[Linux] 文件内容查看 cat,less,more,tail,head,sed

摘要: 本文讲述几种常用文件内容的查看工具,比如cat、more、less、head、tail、sed等

目录

1、cat 显示文件连接文件内容的工具;

1.0cat语法结构;

1.1cat查看文件内容实例;

1.2cat的创建、连接文件功能实例;

2、more 文件内容或输出查看工具;

2.1 more 的语法、参数和动作命令;

2.2more的参数应用举例;

2.3more的动作指令;

2.4其它命令通过管道和more结合的运用例子;

3、less 查看文件内容 工具;

3.1 less的语法格式;

3.2less的动作命令;

4、head工具,显示文件内容的前几行;

5、tail工具,显示文件内容的最后几行;

6、sed简介;

+++++++++++++++++++++++++++++++++++++

正文

+++++++++++++++++++++++++++++++++++++

1、cat 显示文件连接文件内容的工具;

cat 是一个文本文件查看和连接工具。查看一个文件的内容,用cat比较简单,就是cat 后面直接接文件

名。

比如:

[root@localhost~]#cat/etc/fstab

为了便于新手弟兄灵活掌握这个工具,我们多说一点常用的参数;

1.0 cat 语法结构;

cat[选项][文件]...

选项 -A, --show-all 等价于 -vET -b, --number-nonblank 对非空输出行编号 -e 等价于 -vE -E, -

-show-ends 在每行结束处显示 $ -n, --number 对输出的所有行编号 -s, --squeeze-blank 不输出多

行空行 -t 与 -vT 等价 -T, --show-tabs 将跳 字符显示为 ^I -u (被忽略) -v, --show-nonprinting

使用 ^ 和 M- 引用,除了 LFD 和 TAB 之外 --help 显示此帮助信息并离开

1.1 cat 查看文件内容实例;

[root@localhost~]#cat/etc/profile注:查看/etc/目录下的profile文件内容;

[root@localhost ~]# cat -b /etc/fstab   注:查看/etc/目录下的profile内容,并且对非空白行进

行编号,行号从1开始;[root@localhost ~]# cat -n /etc/profile    注:对/etc目录中的profile的所有的行(包括空白行)

进行编号输出显示;[root@localhost ~]# cat  -E /etc/profile     注:查看/etc/下的profile内容,并且在每行的结尾

处附加$符号;cat 加参数-n 和nl工具差不多,文件内容输出的同时,都会在每行前面加上行号;

[root@localhost ~]# cat -n /etc/profile

[root@localhost~]#nl/etc/profile

cat 可以同时显示多个文件的内容,比如我们可以在一个cat命令上同时显示两个文件的内容;

[root@localhost ~]# cat /etc/fstab /etc/profilecat 对于内容极大的文件来说,可以通过管道|传送到more 工具,然后一页一页的查看;

[root@localhost ~]# cat /etc/fstab /etc/profile | more

1.2 cat 的创建、连接文件功能实例;

cat 有创建文件的功能,创建文件后,要以EOF或STOP结束;

[root@localhost~]#cat>linuxsir.org.txt<<EOF注:创建linuxsir.org.txt文件;

> 我来测试 cat 创建文件,并且为文件输入内容;       注:这是为linuxsir.org.txt文件输入内容

>北南南北测试;注:这是为linuxsir.org.txt文件输入内容;

> EOF   注:退出编辑状态;

[root@localhost ~]# cat linuxsir.org.txt  注:我们查看一下linuxsir.org.txt文件的内容;

我来测试 cat 创建文件,并且为文件输入内容;

北南南北测试;

cat 还有向已存在的文件追加内容的功能;

[root@localhost ~]# cat  linuxsir.txt 注:查看已存在的文件linuxsir.txt 内容;

IamBeiNanNanBeiFromLinuxSir.Org.注:内容行

我正在为cat命令写文档

[root@localhost~]#cat>>linuxsir.txt<<EOF注:我们向linuxsir.txt文件追加内容;

>我来测试cat向文档追加内容的功能;注:这是追回的内容

>OK?

>OK~

>北南呈上

> EOF   注:以EOF退出;

[root@localhost~]#catlinuxsir.txt注:查看文件内容,看是否追回成功。

IamBeiNanNanBeiFromLinuxSir.Org.

我正在为cat命令写文档

我来测试cat向文档追加内容的功能; 

OK?

OK~

北南 呈上

cat 连接多个文件的内容并且输出到一个新文件中; 假设我们有sir01.txt、sir02.tx和sir03.txt ,并且内容如下;

[root@localhost ~]# cat sir01.txt 

123456

i am testing

[root@localhost ~]# cat sir02.txt

56789

BeiNan Tested

[root@localhost ~]# cat sir03.txt

09876

linuxsir.orgtesting

我想通过cat 把sir01.txt、sir02.txt及sir03.txt 三个文件连接在一起(也就是说把这三个文件的内

容都接在一起)并输出到一个新的文件sir04.txt 中。

注意:其原理是把三个文件的内容连接起来,然后创建sir04.txt文件,并且把几个文件的内容同时写入

sir04.txt中。特别值得一提的是,如果您输入到一个已经存在的sir04.txt 文件,会把sir04.txt内容

清空。

[root@localhost ~]# cat sir01.txt sir02.txt sir03.txt > sir04.txt

[root@localhost ~]# more sir04.txt

123456

iamtesting

56789

BeiNanTested

09876

linuxsir.orgtesting

cat 把一个或多个已存在的文件内容,追加到一个已存在的文件中

[root@localhost ~]# cat sir00.txtlinuxsir.org forever

[root@localhost ~]# cat sir01.txt sir02.txt sir03.txt >> sir00.txt

[root@localhost ~]# cat sir00.txt

linuxsir.orgforever

123456

iamtesting

56789

BeiNanTested

09876

linuxsir.orgtesting

警告:我们要知道>意思是创建,>>是追加。千万不要弄混了。造成失误可不是闹着玩的;

2、more 文件内容或输出查看工具;

more 是我们最常用的工具之一,最常用的就是显示输出的内容,然后根据窗口的大小进行分页显示,然

后还能提示文件的百分比;

[root@localhost ~]# more /etc/profile

2.1 more 的语法、参数和命令;

more[参数选项][文件]

参数如下: +num 从第num行开始显示; -num 定义屏幕大小,为num行; +/pattern 从pattern 前两行

开始显示; -c 从顶部清屏然后显示; -d 提示Press space to continue, 'q' to quit.(按空 键继

续,按q键退出),禁用响铃功能; -l 忽略Ctrl+l (换页)字符; -p 通过清除窗口而不是滚屏来对

文件进行换页。和-c参数有点相似; -s 把连续的多个空行显示为一行; -u 把文件内容中的下划线去

掉退出more的动作指令是q

2.2 more 的参数应用举例;

[root@localhost~]#more-dc/etc/profile注:显示提示,并从终端或控制台顶部显示;

[root@localhost~]#more+4/etc/profile注:从profile的第4行开始显示;

[root@localhost~]#more-4/etc/profile注:每屏显示4行;

[root@localhost ~]# more +/MAIL /etc/profile     注:从profile中的第一个MAIL单词的前两行开

始显示; 2.3 more 的动作指令;

我们查看一个内容较大的文件时,要用到more的动作指令,比如ctrl+f(或空格键)是向下显示一屏,

ctrl+b是返回上一屏; Enter键可以向下滚动显示n行,要通过定,默认为1行;

我们只说几个常用的;自己尝试一下就知道了;

Enter 向下n行,需要定义,默认为1行; Ctrl+f 向下滚动一屏; 空 键 向下滚动一屏; Ctrl+b 返回

上一屏; = 输出当前行的行号; :f 输出文件名和当前行的行号; v 调用vi编辑器; ! 命令 调用

Shell,并执行命令; q 退出more当我们查看某一文件时,想调用vi来编辑它,不要忘记了v动作指令,这是比较方便的;

2.4 其它命令通过管道和more结合的运用例子;

比如我们列一个目录下的文件,由于内容太多,我们应该学会用more来分页显示。这得和管道 | 结合起

来,比如:

[root@localhost ~]# ls -l /etc  |more

3、less 查看文件内容 工具;

less 工具也是对文件或其它输出进行分页显示的工具,应该说是linux正统查看文件内容的工具,功能

极其强大;您是初学者,我建议您用less。由于less的内容太多,我们把最常用的介绍一下;

3.1 less的语法格式;

less[参数]文件

常用参数

-c从顶部(从上到下)刷新屏幕,并显示文件内容。而不是通过底部滚动完成刷新;

-f强制打开文件,二进制文件显示时,不提示警告;

-i搜索时忽略大小写;除非搜索串中包含大写字母;

-I搜索时忽略大小写,除非搜索串中包含小写字母;

-m显示读取文件的百分比;

-M显法读取文件的百分比、行号及总行数;

-N在每行前输出行号;

-ppattern搜索pattern;比如在/etc/profile搜索单词MAIL,就用less-pMAIL/etc/profile

-s把连续多个空白行作为一个空白行显示;

-Q在终端下不响铃;

比如:我们在显示/etc/profile的内容时,让其显示行号;

[root@localhost ~]# less -N    /etc/profile

3.2 less的动作命令;

进入less后,我们得学几个动作,这样更方便我们查阅文件内容;最应该记住的命令就是q,这个能让

less终止查看文件退出;

动作

回车键向下移动一行;

y向上移动一行;

空格键向下滚动一屏;

b向上滚动一屏;

d向下滚动半屏;

hless的帮助;

u向上洋动半屏;

w可以指定显示哪行开始显示,是从指定数字的下一行显示;比如指定的是6,那就从第7行显示;

g跳到第一行;

G跳到最后一行;

pn%跳到n%,比如10%,也就是说比整个文件内容的10%处开始显示;

/pattern搜索pattern,比如/MAIL表示在文件中搜索MAIL单词;

v调用vi编辑器;

q退出less

!command调用SHELL,可以运行命令;比如!ls显示当前列当前目录下的所有文件;

就less的动作来说,内容太多了,用的时候查一查man less是最好的。在这里就不举例子了;

4、head 工具,显示文件内容的前几行;

head 是显示一个文件的内容的前多少行;

用法比较简单;

head  -n  行数值  文件名;比如我们显示/etc/profile的前10行内容,应该是:

[root@localhost ~]# head -n 10 /etc/profile

5、tail 工具,显示文件内容的最后几行;

tail 是显示一个文件的内容的前多少行;

用法比较简单;

tail   -n  行数值  文件名;比如我们显示/etc/profile的最后5行内容,应该是:

[root@localhost ~]# tail  -n 5 /etc/profile

6.Sed简介

1.1.Sed简介

2.sed 是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为

“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容

送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向

存储输出。Sed主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等。以下介绍

的是Gnu版本的Sed 3.02。  

3.2.定址

4.可以通过定址来定位你所希望编辑的行,该地址用数字构成,用逗号分隔的两个行数表示以这两行为

起止的行的范围(包括行数表示的那两行)。如1,3表示1,2,3行,美元符号($)表示最后一行。范围

可以通过数据,正则表达式或者二者结合的方式确定 。   5. 

6.3. Sed命令  

7.调用sed命令有两种形式:

8.*

9.sed[options]'command'file(s)

10.*

11.sed[options]-fscriptfilefile(s)

12.a\

13.在当前行后面加入一行文本。

14.blable

15.分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾。

16.c\

17.用新的文本改变本行的文本。

18.d

19.从模板块(Patternspace)位置删除行。

20.D

21.删除模板块的第一行。

22.i\

23.在当前行上面插入文本。

24.h

25.拷贝模板块的内容到内存中的缓冲区。

26.H

27.追加模板块的内容到内存中的缓冲区

28.g

29.获得内存缓冲区的内容,并替代当前模板块中的文本。

30.G

31.获得内存缓冲区的内容,并追加到当前模板块文本的后面。

32.l

33.列表不能打印字符的清单。

34.n

35.读取下一个输入行,用下一个命令处理新的行而不是用第一个命令。

36.N

37.追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码。

38.p

39.打印模板块的行。

40.P(大写)

41.打印模板块的第一行。

42.q

43.退出Sed。

44.rfile

45.从file中读行。

46.tlabel

47.if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚

本的末尾。  

48.Tlabel

49.错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到

脚本的末尾。  

50.wfile

51.写并追加模板块到file末尾。

52.Wfile

53.写并追加模板块的第一行到file末尾。

54.!

55.表示后面的命令对所有没有被选定的行发生作用。

56.s/re/string

57.用string替换正则表达式re。

58.=

59.打印当前行号码。

60.#

61.把注释扩展到下一个换行符以前。

62.以下的是替换标记

63.*

64.g表示行内全面替换。

65.*

66.p表示打印行。

67.*

68.w表示把行写入一个文件。

69.*

70.x表示互换模板块中的文本和缓冲区中的文本。

71.*

72.y表示把一个字符翻译为另外的字符(但是不用于正则表达式)

73.

74.4.选项

75.-ecommand,--expression=command

76.允许多台编辑。

77.-h,--help

78.打印帮助,并显示bug列表的地址。

79.-n,--quiet,--silent

80.

81.取消默认输出。

82.-f,--filer=script-file

83.引导sed脚本文件名。

84.-V,--version

85.打印版本和版权信息。

86.

87.5.元字符集^

88.锚定行的开始如:/^sed/匹配所有以sed开头的行。

89.$

90.锚定行的结束如:/sed$/匹配所有以sed结尾的行。

91..

92.匹配一个非换行符的字符如:/s.d/匹配s后接一个任意字符,然后是d。

93.*

94.匹配零或多个字符如:/*sed/匹配所有模板是一个或多个空格后紧跟sed的行。

95.[]

96.匹配一个指定范围内的字符,如/[Ss]ed/匹配sed和Sed。

97.[^]

98.匹配一个不在指定范围内的字符,如:/[^A-RT-Z]ed/匹配不包含A-R和T-Z的一个字母开头,紧跟ed

的行。  

99.\(..\)

100.保存匹配的字符,如s/\(love\)able/\1rs,loveable被替换成lovers。

101.&

102.保存搜索字符用来替换其他字符,如s/love/**&**/,love这成**love**。

103.\<

104.锚定单词的开始,如:/\<love/匹配包含以love开头的单词的行。

105.\>

106.锚定单词的结束,如/love\>/匹配包含以love结尾的单词的行。

107.x\{m\}

108.重复字符x,m次,如:/0\{5\}/匹配包含5个o的行。

109.x\{m,\}

110.重复字符x,至少m次,如:/o\{5,\}/匹配至少有5个o的行。

111.x\{m,n\}

112.重复字符x,至少m次,不多于n次,如:/o\{5,10\}/匹配5--10个o的行。

113.6.实例

114.删除:d命令

115.*

116.$sed'2d'example-----删除example文件的第二行。

117.*

118.$sed'2,$d'example-----删除example文件的第二行到末尾所有行。

119.*

120.$sed'$d'example-----删除example文件的最后一行。

121.*

122.$sed'/test/'dexample-----删除example文件所有包含test的行。

123.替换:s命令

124.*

125.$ sed 's/test/mytest/g' example-----在整行范围内把test替换为mytest。如果没有g标记,则只

有每行第一个匹配的test被替换成mytest。  

126.*

127.$ sed -n 's/^test/mytest/p' example-----(-n)选项和p标志一起使用表示只打印那些发生替换的

行。也就是说,如果某一行开头的test被替换成mytest,就打印它。  

128.*

129.$ sed 's/^192.168.0.1/&localhost/' example-----&符号表示替换换字符串中被找到的部份。所

有以192.168.0.1开头的行都会被替换成它自已加 localhost,变成192.168.0.1localhost。  

130.*

131.$ sed -n 's/\(love\)able/\1rs/p' example-----love被标记为1,所有loveable会被替换成

lovers,而且替换的行会被打印出来。  

132.*

133.$ sed 's#10#100#g' example-----不论什么字符,紧跟着s命令的都被认为是新的分隔符,所以,

“#”在这里是分隔符,代替了默认的“/”分隔符。表示把所有10替换成100。  

134.选定行的范围:逗号

135.*

136.$ sed -n '/test/,/check/p' example-----所有在模板test和check所确定的范围内的行都被打印

。  

137.*

138.$ sed -n '5,/^test/p' example-----打印从第五行开始到第一个包含以test开始的行之间的所有

行。  

139.*

140.$ sed '/test/,/check/s/$/sed test/' example-----对于模板test和west之间的行,每行的末尾

用字符串sed test替换。  

141.多点编辑:e命令

142.*

143.$ sed -e '1,5d' -e 's/test/check/' example-----(-e)选项允许在同一行里执行多条命令。如例

子所示,第一条命令删除1至5行,第二条命令用check替换test。命令的执 行顺序对结果有影响。如果

两个命令都是替换命令,那么第一个替换命令将影响第二个替换命令的结果。  

144.*

145.$ sed --expression='s/test/check/' --expression='/love/d' example-----一个比-e更好的命

令是--expression。它能给sed表达式赋值。  

146.从文件读入:r命令

147.*

148.$ sed '/test/r file' example-----file里的内容被读进来,显示在与test匹配的行后面,如果匹

配多行,则file的内容将显示在所有匹配行的下面。  

149.写入文件:w命令

150.*

151.$sed-n'/test/wfile'example-----在example中所有包含test的行都被写入file里。

152.追加命令:a命令

153.*

154.$ sed '/^test/a\\--->this is a example' example<-----'this is a example'被追加到以test

开头的行后面,sed要求命令a后面有一个反斜杠。  

155.插入:i命令

156.$sed'/test/i\\

157.newline

158.-------------------------'example

159.如果test被匹配,则把反斜杠后面的文本插入到匹配行的前面。

160.下一个:n命令

161.*

162.$ sed '/test/{ n; s/aa/bb/; }' example-----如果test被匹配,则移动到匹配行的下一行,替换

这一行的aa,变为bb,并打印该行,然后继续。  

163.变形:y命令

164.*

165.$ sed '1,10y/abcde/ABCDE/' example-----把1--10行内所有abcde转变为大写,注意,正则表达式

元字符不能使用这个命令。  

166.退出:q命令

167.*

168.$sed'10q'example-----打印完第10行后,退出sed。

169.保持和获取:h命令和G命令

170.*

171.$ sed -e '/test/h' -e '$G example-----在sed处理文件的时候,每一行都被保存在一个叫模式空

间的临时缓冲区中,除非行被删除或者输出被取消,否则所有被处理的行都将 打印在屏幕上。接着模式

空间被清空,并存入新的一行等待处理。在这个例子里,匹配test的行被找到后,将存入模式空间,h命

令将其复制并存入一个称为保 持缓存区的特殊缓冲区内。第二条语句的意思是,当到达最后一行后,G

命令取出保持缓冲区的行,然后把它放回模式空间中,且追加到现在已经存在于模式空间中 的行的末尾

。在这个例子中就是追加到最后一行。简单来说,任何包含test的行都被复制并追加到该文件的末尾。 

 

172.保持和互换:h命令和x命令

173.*

174.$ sed -e '/test/h' -e '/check/x' example -----互换模式空间和保持缓冲区的内容。也就是把

包含test与check的行互换。  

175.7.脚本

176.Sed脚本是一个sed的命令清单,启动Sed时以-f选项引导脚本文件名。Sed对于脚本中输入的命令非

常挑剔,在命令的末尾不能有任何空白或文本,如果在一行中有多个命令,要用分号分隔。以#开头的行

为注释行,且不能跨行。 

1.Sed简介

sed 是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“

模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送

往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存

储输出。Sed主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等。以下介绍的

是Gnu版本的Sed 3.02。

2.定址

可以通过定址来定位你所希望编辑的行,该地址用数字构成,用逗号分隔的两个行数表示以这两行为起

止的行的范围(包括行数表示的那两行)。如1,3表示1,2,3行,美元符号($)表示最后一行。范围可

以通过数据,正则表达式或者二者结合的方式确定 。

3. Sed命令

调用sed命令有两种形式:

*

sed[options]'command'file(s)

*

sed[options]-fscriptfilefile(s)

a\

在当前行后面加入一行文本。

blable

分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾。

c\

用新的文本改变本行的文本。

d

从模板块(Patternspace)位置删除行。

D

删除模板块的第一行。

i\

在当前行上面插入文本。

h

拷贝模板块的内容到内存中的缓冲区。

H

追加模板块的内容到内存中的缓冲区

g

获得内存缓冲区的内容,并替代当前模板块中的文本。

G

获得内存缓冲区的内容,并追加到当前模板块文本的后面。

l

列表不能打印字符的清单。

n

读取下一个输入行,用下一个命令处理新的行而不是用第一个命令。

N

追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码。

p

打印模板块的行。

P(大写)

打印模板块的第一行。

q

退出Sed。

rfile

从file中读行。

tlabel

if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本

的末尾。

Tlabel

错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚

本的末尾。

wfile

写并追加模板块到file末尾。

Wfile

写并追加模板块的第一行到file末尾。

!

表示后面的命令对所有没有被选定的行发生作用。

s/re/string

用string替换正则表达式re。

=

打印当前行号码。

#

把注释扩展到下一个换行符以前。

以下的是替换标记

*

g表示行内全面替换。

*

p表示打印行。

*

w表示把行写入一个文件。

*

x表示互换模板块中的文本和缓冲区中的文本。

*

y表示把一个字符翻译为另外的字符(但是不用于正则表达式)

4. 选项

-ecommand,--expression=command

允许多台编辑。

-h,--help

打印帮助,并显示bug列表的地址。

-n, --quiet, --silent

取消默认输出。

-f,--filer=script-file

引导sed脚本文件名。

-V,--version

打印版本和版权信息。

5. 元字符集^

锚定行的开始如:/^sed/匹配所有以sed开头的行。

$

锚定行的结束如:/sed$/匹配所有以sed结尾的行。

.

匹配一个非换行符的字符如:/s.d/匹配s后接一个任意字符,然后是d。

*

匹配零或多个字符如:/*sed/匹配所有模板是一个或多个空格后紧跟sed的行。

[]

匹配一个指定范围内的字符,如/[Ss]ed/匹配sed和Sed。

[^]

匹配一个不在指定范围内的字符,如:/[^A-RT-Z]ed/匹配不包含A-R和T-Z的一个字母开头,紧跟ed的行

\(..\)

保存匹配的字符,如s/\(love\)able/\1rs,loveable被替换成lovers。

&

保存搜索字符用来替换其他字符,如s/love/**&**/,love这成**love**。

\<

锚定单词的开始,如:/\<love/匹配包含以love开头的单词的行。

\>

锚定单词的结束,如/love\>/匹配包含以love结尾的单词的行。

x\{m\}

重复字符x,m次,如:/0\{5\}/匹配包含5个o的行。

x\{m,\}

重复字符x,至少m次,如:/o\{5,\}/匹配至少有5个o的行。

x\{m,n\}

重复字符x,至少m次,不多于n次,如:/o\{5,10\}/匹配5--10个o的行。

6.实例

删除:d命令

*

$sed'2d'example-----删除example文件的第二行。

*

$sed'2,$d'example-----删除example文件的第二行到末尾所有行。

*

$sed'$d'example-----删除example文件的最后一行。

*

$sed'/test/'dexample-----删除example文件所有包含test的行。

替换:s命令

*

$ sed 's/test/mytest/g' example-----在整行范围内把test替换为mytest。如果没有g标记,则只有每

行第一个匹配的test被替换成mytest。

*

$ sed -n 's/^test/mytest/p' example-----(-n)选项和p标志一起使用表示只打印那些发生替换的行。

也就是说,如果某一行开头的test被替换成mytest,就打印它。

*

$ sed 's/^192.168.0.1/&localhost/' example-----&符号表示替换换字符串中被找到的部份。所有以

192.168.0.1开头的行都会被替换成它自已加 localhost,变成192.168.0.1localhost。

*

$ sed -n 's/\(love\)able/\1rs/p' example-----love被标记为1,所有loveable会被替换成lovers,

而且替换的行会被打印出来。

*

$ sed 's#10#100#g' example-----不论什么字符,紧跟着s命令的都被认为是新的分隔符,所以,“#”

在这里是分隔符,代替了默认的“/”分隔符。表示把所有10替换成100。

选定行的范围:逗号

*

$sed-n'/test/,/check/p'example-----所有在模板test和check所确定的范围内的行都被打印。

*

$sed-n'5,/^test/p'example-----打印从第五行开始到第一个包含以test开始的行之间的所有行。

*

$ sed '/test/,/check/s/$/sed test/' example-----对于模板test和west之间的行,每行的末尾用字

符串sed test替换。

多点编辑:e命令

*

$ sed -e '1,5d' -e 's/test/check/' example-----(-e)选项允许在同一行里执行多条命令。如例子所

示,第一条命令删除1至5行,第二条命令用check替换test。命令的执 行顺序对结果有影响。如果两个

命令都是替换命令,那么第一个替换命令将影响第二个替换命令的结果。

*

$ sed --expression='s/test/check/' --expression='/love/d' example-----一个比-e更好的命令是

--expression。它能给sed表达式赋值。

从文件读入:r命令

*

$ sed '/test/r file' example-----file里的内容被读进来,显示在与test匹配的行后面,如果匹配多

行,则file的内容将显示在所有匹配行的下面。

写入文件:w命令

*

$sed-n'/test/wfile'example-----在example中所有包含test的行都被写入file里。

追加命令:a命令

*

$ sed '/^test/a\\--->this is a example' example<-----'this is a example'被追加到以test开头

的行后面,sed要求命令a后面有一个反斜杠。

插入:i命令

$sed'/test/i\\

newline

-------------------------'example

如果test被匹配,则把反斜杠后面的文本插入到匹配行的前面。

下一个:n命令

*

$ sed '/test/{ n; s/aa/bb/; }' example-----如果test被匹配,则移动到匹配行的下一行,替换这一

行的aa,变为bb,并打印该行,然后继续。

变形:y命令

*

$ sed '1,10y/abcde/ABCDE/' example-----把1--10行内所有abcde转变为大写,注意,正则表达式元字

符不能使用这个命令。

退出:q命令

*

$sed'10q'example-----打印完第10行后,退出sed。

保持和获取:h命令和G命令

*

$ sed -e '/test/h' -e '$G example-----在sed处理文件的时候,每一行都被保存在一个叫模式空间的

临时缓冲区中,除非行被删除或者输出被取消,否则所有被处理的行都将 打印在屏幕上。接着模式空间

被清空,并存入新的一行等待处理。在这个例子里,匹配test的行被找到后,将存入模式空间,h命令将

其复制并存入一个称为保 持缓存区的特殊缓冲区内。第二条语句的意思是,当到达最后一行后,G命令

取出保持缓冲区的行,然后把它放回模式空间中,且追加到现在已经存在于模式空间中 的行的末尾。在

这个例子中就是追加到最后一行。简单来说,任何包含test的行都被复制并追加到该文件的末尾。

保持和互换:h命令和x命令

*

$ sed -e '/test/h' -e '/check/x' example -----互换模式空间和保持缓冲区的内容。也就是把包含

test与check的行互换。

7.脚本

Sed脚本是一个sed的命令清单,启动Sed时以-f选项引导脚本文件名。Sed对于脚本中输入的命令非常挑

剔,在命令的末尾不能有任何空白或文本,如果在一行中有多个命令,要用分号分隔。以#开头的行为注

释行,且不能跨行。 

sed真的可以大大提高我们的工作效率,下面就写了这样一行,好多文件都被替换了,真方便

Java代码

1.sed's/localhost/127.0.0.1/g'mysql_virtual_*.cf

相关推荐