天天看点

Sed命令总汇

Sed命令总汇

1.:

用法:

:lable

在脚本中标记一行,用于实现由b或t的控制转移。Label最多可以包含7个字符

2.=

=[address]=

将所寻址的行编写到标准输出

3.a

[address]a

text

在与address匹配的每行后面追加text。如果text多于一行,必须用反斜杠将这些行前面的换行符“隐藏”起来。Text将被没有用这

种方法隐藏的第一个换行符结束。Text在模式空间中是不可用的并且后续的命令不能应用于它。当编辑命令的列表用完时,这个命令

的结果将被输送到标准输出,而不管在模式空间中的当前行发生了什么。

4.b

[address1[,address2]]b[label]

无条件地将控制转移到脚本的其他位置的:label处。也就是说,label后面的命令是应用于当前行的下一个命令。如果没有指定

label, 控制将一直到达脚本的末端,因此不再有命令作用于当前行。

5.c

[address1[,address2]]c

用text替代(改变)由地址选定的行。当指定的是一个行范围时,将所有的这些行作为一个组由text的一个副本来替代。每个text行

后面的换行符必须用反斜杠将其转义,但最后一行除外。实际上,模式空间的内容被删除,因此后续的命令不能应用于它(或应用于text)

6.d

[address1[,address2]]d

从模式空间中删除行。因此行没有传递到标准输出。一个新的输入行被读取,并用脚本的第一个命令来编辑。

7.D

[address1[,address2]]D

删除由命令N创建的多行模式空间中的一部分(直到嵌入的换行符),并且用脚本的第一条命令恢复编辑。如果这个命令使模式空间

为空,那么将读取一个新的输入行,和执行了d命令一样。

8.g

[address1[,address2]]g

将保持空间(参见h或H命令)中的内容复制到模式空间中,并将当前的内容清除。

9.G

[address1[,address2]]G

将换行符后的保持空间(参见h或H命令)内容追加到模式空间。如果保持空间为空,则将换行符添加到模式空间。

10.h

[address1[,address2]]h

将模式空间的内容复制到保存空间,即一个特殊的临时缓冲区。保存空间的当前内容被清除。

11.H

[address1],address2]]H

将换行符和模式空间的内容追加到保持空间中,即使保持空间为空,这个命令也追加换行符。

12.i

[address1]i

将text插入到每个和address匹配的行的前面

13.l

[address1[,address2]]l

列出模式空间的内容,将不可打印的字符表示为ASCII码。长的行被折行。

14.n

[address1[,address2]]n

读取下一个输入行到模式空间。当前行被送到标准输出。新行成为当前行并递增行计数器。将控制转到n后面的命令,而不是恢复到

脚本的顶部。

15.N

[address1[,address2]]N

将下一个输入行追加到模式空间的内容之后;新添加的行与模式空间的当前内容用换行符分隔(这个命令用于实现跨两行的模式匹配

。利用n来匹配嵌入的换行符,则可以实现多行匹配模式)。

16.p

[address1[,address2]]p

打印所寻址的行。注意这将导致输出的重复,除非默认的输出用”#n”或”-n”命令行选项限制。常用于改变流控制(d,n,b)的命

令之前并可能阻止当前行被输出。

17.P

[address1[,address2]]P

打印由命令N创建的多行模式空间的第一部分(直接嵌入的换行符)。如果没有将N应用于某一行则和p相同。

18.q

[address]q

当遇到address时退出。寻址的行首先被写到输出(如果没有限制默认输出),包括前面的a或r命令为它追加的文本。

19.r

[address]r file

读取file的内容并追加到模式空间内容的后面。必须在r和文件名file之间保留一个空格。

20.s

[address1[,address2]]s/pattern/replacement/[flags]

用replacement代替每个寻址的pattern。如果使用了模式地址,那么模式//表示最后指定的模式地址。可以指定下面的标志:

       n 替代每个寻址的行的第n个/pattern/。N是1到512之间的任意数字,并且默认值为1。

       g 替代每个寻址的行的所有/pattern/,而不只是第一个

       p 如果替换成功则打印这一行。如果成功进行了多个替换,将打印这个行的多个副本。

       w file 如果发生一次替换则将这行写入file。最多可以打开10个不同的file。

replacement是一个字符串,用来替换与正则表达式匹配的内容.在replacement部分,只有下列字符有特殊含义:

    & 用正则表达式匹配的内容进行替换

    n 匹配第n个子串(n是一个数字),这个子串以前在pattern中用"("和")"指定.

      当在替换部分包含"与"符号(&),反斜杠()和替换命令的定界符时可用转义它们.另外,它用于转义换行符并创建多行

replacement字符串.

数字标志

s/pattern/replacememt/flag

如果flag是数字, 那么指定对一行上某个位置的匹配.如果没有数字标志,则替换命令只替换第一个匹配串,因此"1"可以被看作是默认

的数字标志.

替换元字符是反斜杠()、与符号(&)和n。

反斜杠一般用于转义其他的元字符,但是它在替换字符串中也用于包含换行符。

例如对于如下的行:

column1(制表符)column2(制表符)column3(制表符)column4

使用如下替换语句:

s/制表符/

/2

注意,在反斜杠的后面不允许有空格。这个脚本产生下面的结果:

column1(制表符)column2

column3(制表符)column4

"与"符号(&)作为元字符表示模式匹配的范围,不是被匹配的行.例如下面的命令:

s/UNIX/s-2&s0/g

可以将输入行:

on the UNIX Operating System.

替换成:

on the s-2UNIXs0 Operating System.

当正则表达式匹配单词的变化时,"与"符号特别有用.它允许指定一个可变的替换字符串.诸如"See Section 1.4"或"See Section

12.9"的引用都应该出现在圆括号中,如"(See Section 12.9)".正则表达式可以匹配数字的不同组合,所以在替换字符串中可以使用

"&"并括起所匹配的内容:

s/See Section [1-9][0-9]*.[1-9][0-9]*/(&)/

这里"与"符号用于在替换字符串中引用整个匹配内容.

n元字符用于选择被匹配的字符串的任意独立部分,并且在替换字符串中回调它.在sed中转义的圆括号括住正则表达式的任意部分并

且保存以备回调.一行最多允许保存9次.例如,当节号出现在交叉引用中时要表示为用粗体:

s/(See Section )([1-9][0-9]*.[1-9][0-9]*)/1fB2fp/

再来看另外一个例子:

$ cat test1

first:second

one:two

$ sed 's/(.*):(.*)/2:1/ test1

second:first

two:one

21.t

[address1[,address2]]t[label]

测试在寻址的行范围内是否成功执行了替换,如果是,则转移到有label标志的行(参见b和:)。如果没有给出label,控制将转移到

脚本的底部。

22.w

[address1[,address2]]w file

将模式空间的内容追加到file。这个动作是在遇到命令时发生而不是在输出模式空间内容时发生。必须在w和这个文件名之间保留一

个空格。在脚本中可以打开的最大文件数是10。如果文件不存在,这个命令将创建一个文件。如果文件存在,则每次执行脚本时将改

写其内容,多重写入命令直接将输出写入到同一个文件并追加到这个文件的末端。

23.x

[address1[,address2]]x

交换模式空间和保持空间的内容。

24.y

[address1[,address2]]y/abc/xyz/

按位置将字符串abc中的字符替换成字符串xyz中相应字符。