命令格式:
sed [options] 'command' file(s)
sed [options] -f scriptfile file(s)
选项:
参数 | 完整参数 | 说明 |
---|---|---|
-e script | --expression=script | 以选项中的指定的script来处理输入的文本文件 |
-f script | --files=script | 以选项中的指定的script文件来处理输入的文本文件 |
-h | --help | 显示帮助 |
-n | --quiet --silent | 仅显示script处理后的结果 |
-V | --version | 显示版本信息 |
sed命令:
命令 | 说明 |
---|---|
d | 删除,删除选择的行 |
D | 删除模板块的第一行 |
s | 替换指定字符 |
h | 拷贝模板块的内容到内存中的缓冲区 |
H | 追加模板块的内容到内存中的缓冲区 |
g | 获得内存缓冲区的内容,并替代当前模板块中文本 |
G | 获得内存缓冲区的内容,并追加到当前模板块文本的后面 |
l | 列表不能打印字符的清单 |
n | 读取下一个输入行,用下一个命令处理新的行而不是第一个命令 |
N | 追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码 |
p | 打印模板块的行 |
P | 打印模板块的第一行 |
q | 退出sed |
b label | 分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾 |
r file | 从file中读行 |
t label | if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾 |
T label | 错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾 |
w file | 写并追加模板块到file末尾 |
W file | 写并追加模板块的第一行到file末尾 |
! | 表示后面的命令对所有没有被选定的行发生作用 |
= | 打印当前行号 |
# | 把注释扩展到第一个换行符以前 |
sed替换标记:
命令 | 说明 |
---|---|
g | 表示行内全面替换 |
p | 表示打印行 |
w | 表示把行写入一个文件 |
x | 表示互换模板块中的文本和缓冲区中的文本 |
y | 表示把一个字符翻译为另外的字符(但是不用于正则表达式) |
\1 | 子串匹配标记 |
& | 已匹配字符串标记 |
sed元字符集:
命令 | 说明 |
---|---|
^ | 匹配行开始,如:/^sed/匹配所有以sed开头的行。 |
$ | 匹配行结束,如:/sed$/匹配所有以sed结尾的行。 |
. | 匹配一个非换行符的任意字符,如:/s.d/匹配s后接一个任意字符,最后是d。 |
* | 匹配0个或多个字符,如:/*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次,如:/0{5}/匹配包含5个0的行。 |
x{m,} | 重复字符x,至少m次,如:/0{5,}/匹配至少有5个0的行。 |
x{m,n} | 重复字符x,至少m次,不多于n次,如:/0{5,10}/匹配5~10个0的行。 |
sed是一种流编辑器。
从标准输入中读取需要处理的行,存储在缓冲区(模式空间)中,然后用sed命令进行处理,最后将处理结果送到标准输出。
准备test文件:
认识定界符:/
在sed命令中,隔绝原字符和新字符的不是空格,而是定界符。定界符可以由任意字符代替,但一般都用/。
s/old/new/ 以为将old替换成new
当/本身为需要替换的内容时,要转义。
1:替换文本中的字符串,将结果输出到屏幕,不改变原文本内容。sed 's/This/abc/' file1
2:替换文本中的字符串,只将改变部分输出到屏幕,不改变原文本内容。sed -n 's/This/abc/p' file1
3:替换文本中的字符串,直接作用于原文件。sed -i 's/This/abc/' file1
4:sed 's/This/abc/' file1只能匹配每行第一个This,如果要将所有都匹配替换,需要加g标记
5:从每行的第N个元素才开始匹配替换,需要将g标记换成Ng
6:删除空白行 sed '/^$/d' file1
7:删除第N行 sed 'Nd' file1
8:删除第N行到最后一行 sed 'N,$d' file1
9:删除最后一行 sed '$d' file1
10:删除特定字符开头的行 sed '/this/d' file1
11:匹配到的字符标记为&,可以对其进行操作,例如对于每个单词都加方括号。 sed 's/\w\+/[&]/g' file1
12:匹配固定样式,得到多个子串,如何操作子串?
命令中my cat(dog/fish),被替换成cat(dog/fish).样式匹配到的子串是cat,dog,fish,\(..\)用于匹配子串,对于匹配到的第一个子串标记为\1,依此类推匹配到的第二个结果就是\2
13:匹配固定字符后,读取另一文件内容,输出到屏幕。sed '/my/r file' file1
14:匹配固定字符后,输入到另一文件。sed '/my/w file' file1
15:匹配固定字符后,追加新内容。 sed '/^my/a\this is a best line' file1
16:在第N行后插入。 sed 'Na\this is a best line' file1
17:匹配固定字符后,在前面插入新内容。 sed '/^my/i\this is a best line' file1
18:当匹配到一行时,自动移动到下一行进行替换等操作。 sed '/my/{n;s/my/My/;}' file1
19:变形操作,例如大小写转变。将前四行的sbcde全部变为大写。sed '1,4y/abcde/ABCDE/' file1
20:打印前几行 sed 'Nq' file1
21:打印奇数行 sed -n 'p;n' file1
打印偶数行 sed -n 'n;p' file1