sed的语法格式:

sed [option] {sed-command} {input-file}

sed在正常情况下,将处理的行读入模式空间(pattern space),脚本中的“sed-command(sed命令)”就一条接着一条进行处理,知道脚本执行完毕。然后该行呗输出,模式(pattern space)被清空;接着,在重复执行刚才的动作,文件中的新的一行被读入,直到文件处理完毕。

sed n/N使用说明-LMLPHP

但是,由于种种原因,如用户希望在某个条件下,脚本中的某个命令被执行或希望模式空间(pattern space)保留,以便下一次使用,这都有可能使sed在处理文件的时候,不按照正常的流程来进行处理,这时候就需要用sed高级命令来满足需求。

先来说说命令n和命令N

命令n:读取下一行到pattern space。由于pattern space中有按照正常流程读取的内容,使用n命令后,pattern space中又有了一行,此时,pattern space中有2行内容,但是先读取的那一行不会被取代、覆盖或删除;当n命令后,还有其他命令p的时候,此时打印出的结果是n命令读取的那一行的内容。

看下图,你就明白了。

新建文件,其内容如下

cat 1.txt

1

2

正常sed流程

sed n/N使用说明-LMLPHP

使用n命令后,

sed n/N使用说明-LMLPHP

N命令:将下一行添加到pattern space中。将当前读入行和用N命令添加的下一行看成“一行”。

新建文件1.txt

cat 1.txt

1

2

正常sed流程

sed n/N使用说明-LMLPHP

使用N命令后

sed n/N使用说明-LMLPHP

=========================================================

2、sed选项
   -n    使用安静模式.则只有经过sed特殊处理的哪一行才会被列出来
   -e    传送带(前面执行完传递给后面)
   -f    跟随脚本文件名
   -r    脱意
   -i    直接修改读取文件

3、sed命令详解
   a     新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~
   c     取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
   d     删除,因为是删除啊,所以 d 后面通常不接任何咚咚;
   i      插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
   p     列印,亦即将某个选择的资料印出。通常 p 会与参数 sed -n 一起运作~
   s     取代,通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g 
   n    读取下一个输入行, 用下一个命令处理新的行

4、以下是替换标记
  g    表示行内全面替换
  p    表示打印行
  w    表示把行写入一个文件
  x    表示互换模快板中的文本和缓冲区中的文本
  y    表示把一个字符翻译为另外的字符(不用于正则表达式)

5、元字符集,匹配符
^       锚定行的开始. 如/^sed/ 匹配所有以sed开头的行
$       锚定行的结束. 如/sed$/ 匹配所有以sed结尾的行
.         匹配一个非换行符. 如/*sed/ 匹配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结尾的单词行
x\{m\}       重复字符x,m次. 如/o\{5\}匹配包含5个o的行
x\{m,\}      重复字符x,至少m次. 如 /o\{5,}/匹配至少有5个o的行
x\{m,n\}    重复字符x,至少m次.把多余n次. 如 /o\{5,10\}/匹配5-10个o的行

6、sed中查找模式匹配
.            单字通配符
[0-9]      匹配0-9
[^a-z]    不匹配a-z的所有其它字符
“.*”         匹配””内任何字符串
^            匹配行开始
$            匹配行结束

7、例子
删除: dd命令
sed ‘2d’ file                 删除file文件的第2行
sed ‘2,$d’ file             删除file文件的第2行到末尾所有行
sed ‘$d’ file                删除file文件的最后一行
sed ‘/test/’d file         删除file文件所有包含test的行
sed d file                   删除file文件中的所有行
sed 2,5d file              删除file中的2-5行
sed /abc/d file          删除file中包含字符串abc所有的行

替换: s命令
sed ‘s/test/mytest/g’ file        在整行范围内把test替换为mytest. 如果没有g标记,则只有每行第一个匹配的test被替换成mytest
sed -n ‘s/^test/mytest/p’ file        -n选项和p标志一起使用表示只打印那些发生替换的行, 如果某一行开头的test被替换成mytest,就打印它
sed ‘s/^192.168.1.1/&localhost’ file    &符号表示替换字符串中被找到的部分. 所有以192.168.1.1开头的行都会被替换成它自己加localhost,变成192.168.1.1localhost
sed -n ‘s/\(love\)able/\1rs/p’ file    love被标记为1,所有loveable会被替换成lovers,而且替换的行会被打印出来
sed ‘s#10#100#g’ file            不论什么字符,紧跟着s的命令都被认为是最新的分隔符,所以,’#’在这里是分隔符,代替了默认的”/”分隔符. 表示把所有10替换成100

选定行的范围: 逗号
sed -n ‘/test/,/check/p’ file        所有在模块test和check所确定范围内的行都被打印
sed -n ‘5,/^test/p’ file                 打印从第5行开始到第一个包含以test开始行之间的所有行
sed ‘/test/,/check/s/$/sed test/’ file    对于模块test和west之间的行,每行的末尾用字符串sed test替换

多点编辑: e命令
sed -e ‘1,5d’ -e ‘s/test/check/’ file    -e选项允许在同一行里执行多条命令.删除1-5行,check替换test
sed -e ‘/and/s/aaa/bbb’ file           sed中用bbb替换同一行中包括字符串and的字符串aaa,而不是每一行中的字符串aaa

读入文件: r命令
sed ‘/test/r file_a’ file        file_a里的内容被读进来,显示在与test匹配的行后面. 如果匹配多行,则file_a内容将显示在所有匹配行的下面

写入文件: w命令
sed -n ‘test/w file_a’ file        file中所包含的test行都被写入file里

插入: i命令
sed ‘/test/i\\ new line’ file        如果test被匹配, 则把反斜杠后面的文本插入到匹配行的上面
sed -e ‘1 ia’ -e ‘$ a3′ file             在第一行上面插入a,在末尾行下面插入3

下一个: n命令
sed ‘/test/{n; s/aa/bb/;}; file        如果test被匹配, 则移动到匹配行的下一行,替换这一行的aa变为bb, 并打印该行,然后继续

05-18 06:03
查看更多