sed原理及sed命令格式 ,缓存区,模式空间


4.1            Sed工作原理

 

sed是一个非交互式的流编辑器。所谓非交互式,是指使用sed只能在命令行下输入编辑命令来编辑文本,然后在屏幕上查看输出;而所谓流编辑器,是指sed每次只从文件(或输入)读入一行,然后对该行进行指定的处理,并将结果输出到屏幕(除非取消了屏幕输出又没有显式地使用打印命令),接着读入下一行。整个文件像流水一样被逐行处理然后逐行输出。

 

下面我们看一下sed的工作过程。

 

sed不是在原输入上直接进行处理的,而是先将读入的行放到缓冲区中,对缓冲区里的内容进行处理,处理完毕后也不会写回原文件(除非用shell的输出重定向来保存结果),而是直接输出到屏幕上。sed运行过程中维护着两个缓冲区,一个是活动的“模式空间(pattern space)”,另一个是起辅助作用的“暂存缓冲区(holding space)”。一般情况下,每当运行sedsed首先把第一行装入模式空间,进行处理后输出到屏幕,然后将第二行装入模式空间替换掉模式空间里原来的内容,然后进行处理,以此类推。

 

一般情况下暂存缓冲区是用不到的,但有特殊的命令可以在模式空间与暂存缓冲区之间交换数据,后文将有介绍。由于sed对文本的所有操作都是在缓冲区里进行的,所以不会对原文件造成任何破坏。

 

4.2            Sed命令格式

 

sed的命令格式如下:

 

sed [-Options] [‘Commands’] filename


 

其中,Command是一个sed命令,sed命令一定要被包含在一对单引号中,以免被shell解释,其格式如下:

 

[address-range][sed-command]或

[Pattern-to-match][sed-command]

 

address-range是指要处理的行的范围,又叫地址范围;pattern-to-match是一个要匹配的模式,是一个正则表达式,sed-command是一个sed命令,用来对指定的行进行处理。下面是一个简单的例子:

 

sed –n ‘1,3p’ students

这个命令将文件students中的第13行打印到屏幕。注意,地址范围和sed命令之间没有空格,如果加入空格,sed也会将其忽略。参数-n用来取消默认输出。默认情况下,sed每读入一行到模式空间,无论是否对其进行处理,在读入下一行之前多要将模式空间中的内容输出到屏幕上。参数-n可以用来取消这种默认的输出,只有当用户用命令p时才将指定的行输出到屏幕。如果没有用参数-n而又对指定行执行了p命令,那么这些行将会被打印两次。

 

地址范围可以是一个数字,这个数字代表了一个行号;也可以是一个用逗号分隔的两个数字表示的范围(包括这两行)。范围可以是数字,正则表达式,或是两者的组合。

 

pattern-to-match是一个要匹配的模式,sed将会对所有匹配的行执行sed-command。其实,这里的pattern-to-match也可以看作是一个地址,这个地址是所有与指定模式匹配的行的行号。因此sed的格式可以归纳为一种:

sed [-Options] ‘[address-range][sed-command]’ filename

 

看不明白的接着看下面的示例解释:
sed -n '1,3 p' a.txt  #sed 命令 -n(sed的命令行选项----取消标准输出) 1,3 (读到缓冲区处理的地址范围) p(sed命令--这个命令表示要怎样处理缓冲区的内容,p是打印输出缓存区内容)

sed -n '1,3 s/11/88/p;' a.txt #把1,3行读到缓冲区,处理缓冲区操作是 s/11/88/p 即替换其中的第一个11为88 p是打印结果。

sed -n '1,3 s/11/88/gp;' a.txt #把1,3行读到缓冲区,处理缓冲区操作是 s/11/88/gp 即替换其中的所有的(g命令表示所有,正则的全局匹配)11为88 p是打印结果。

sed -n 's/11/88/gp' a.txt  #这个命令,由于没有定义范围,sed默认逐行读内容到缓冲区,并使用s/11/88/gp 命令处理。即:每读一行处理一次。

下面看个复杂的:
sed -n ':lb; /start/,/end/{/end/! {$! {N;b lb}}}; s/333.*555/8888/; p;' a.txt 

#上面的解释:

{}是sed命令里的语句块

:lb  是send的label 功能,类似,c语言里的goto lable功能。  lb 是label名称可以自已随便起

:lb; /start/,/end/{/end/! {$! {N;b lb}}}; 可以简化成:lb; /start/,{/end/! {$! {N;b lb}}}; 表示范围是/start/开始,{/end/! {$! {N;b lb}}};结束的内容读到缓冲区。

s/333.*555/8888/; p; 使用这个命令处理缓冲区的内容。

其中:

/end/! {$! {N;b lb}}  中,/end/! 如果不end 那么就 执行这个块{$! {N;b lb}},$!表示如果也不是结尾,就是N循环lb 的label块。 即:只要没有遇见end字符串(/end/!),也没到文档结尾($!),就是一至一行一行读内容到缓冲区。



相关sed的命令,网上有很多资料,大家直接问度娘和谷哥。
http://blog.csdn.net/samxx8/article/details/39054647











评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值