一、简介
Sed是stream editor的简称,也就是流编辑器。它一次处理一行内容,处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存储输出。
二、sed命令语法格式
1、命令格式
sed [options] 'command' file(s)
sed [options] -f scriptfile file(s)
2、选项(option)
参数 |
说明 |
-e |
以选项中的指定的script字符串来处理输入的文本文件 |
-f |
以选项中的指定的script文件来处理输入的文本文件 |
-n |
仅显示script处理后的结果 |
-i |
直接修改读取的文件内容,而不是由屏幕输出 |
-r |
支持扩展的正则表达式(默认是基础正则表达式) |
3、操作命令
参数 |
说明 |
a\ |
在当前行后添加一行或多行 |
c\ |
用新文本修改(替换)当前行中的文本 |
d |
删除行 |
i\ |
在当前行之前插入文本 |
h |
把模式空间里的内容复制到暂存缓存区 |
H |
把模式空间里的内容追加到暂存缓存区 |
g |
取出暂存缓冲区里的内容,将其复制到模式空间,覆盖该处原有内容 |
G |
取出暂存缓冲区里的内容,将其复制到模式空间,追加在原有内容后面 |
l |
列出非打印字符 |
p |
打印行 |
n |
读入下一输入行,并从下一条命令而不是第一条命令开始处理 |
q |
结束或退出 sed |
r |
从文件中读取输入行 |
s |
用一个字符串替换另一个 |
! |
对所选行以外的所有行应用命令 |
4、替换标记
参数 |
说明 |
g |
在行内进行全局替换 |
p |
打印行 |
w |
将行写入文件 |
x |
互换模板块和缓冲区中的文本 |
y |
将字符转换为另一字符(不能对正则表达式使用 y 命令) |
5、正则表达式
元字符 |
功能 |
例子 |
说明 |
^ |
行首定位符 |
/^abcd/ |
匹配所有以abcd开头的行 |
$ |
行尾定位符 |
/abcd$/ |
匹配所有以abcd结束的行 |
. |
匹配除换行外的单个字符 |
/a..d/ |
匹配包含字符a,后跟两个任意字符,再跟字母d的行 |
* |
匹配零个或多个字符 |
/*abcd/ |
|
[] |
匹配指定字符组内任一字符 |
[aA]bcd |
匹配包含abcd或Abcd的行 |
[^] |
匹配不在指定字符组内的任一字符 |
/[^A-E]bcd/ |
匹配包含bcd,但bcd之前的那个字符不在A至E之间的行 |
\(..\) |
保存已匹配的字符 |
|
|
& |
保存查找串以便在替换串中引用 |
s/abcd/**&**/ |
符号&代表匹配的字符串。字符串abcd将替换前后各加了两个**,即abcd变成**abcd** |
\< |
词首定位符 |
/\<abcd/ |
匹配包含以abcd开头的单词的行 |
\> |
词尾定位符 |
/abcd\>/ |
匹配包含以abcd结尾的单词的行 |
x\{m\} |
连续m个x |
/a\{5\}/ |
匹配出现连续5个字母a的行 |
x\{m,\} |
至少m个x |
/a\{5,\}/ |
匹配至少有连续的5个字母a的行 |
x\{m,n\} |
至少m个x但不超过n个x |
/a\{5,10\}/ |
匹配出现5-10个字母a的行 |