sed 命令介绍
sed:Stream Editor 文本编辑,是一个非交互式的命令行工具,能够完美的配合正则表达式使用,功能非常强大,处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”,然后用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕,接着处理下一行,这样不断重复,走到文件未尾。sed 主要用来自动编辑一个或者多个文件 ,可以将数据行进行替换,删除新增,选取等特定工作,简化对文件 的反复操作,编写转换程序等。
命令格式
sed [options] 'command' file(s);
sed [options] -f scriptfile file(s);
选项 |
作用 |
-e |
直接在命令行模式上进行 sed 动作编辑,此为默认选荐 |
-f |
将sed 的动作写在一个文件 内,用-f filename 执行 filename内的sed动作 |
-i |
直接个性文件的内容 |
-n |
只打印模式匹配的行 |
-r |
支持扩展表达式 |
-h |
显示帮助信息 |
-v |
显示版本号 |
命令 |
作用 |
a\ |
在当前行下面插入文本 |
i\ |
在当前行上面插入文本 |
c\ |
把选定的行改为新的文本 |
d |
删除,删除选择的行 |
D |
删除模板块的第一行 |
s |
替换指定字符 |
h |
拷贝模板块的内容到内存中的缓冲区 |
H |
追加模板块的内容到内存中的缓冲区 |
g |
获得内存缓冲区的内容,并替代当前模板块中的文本 |
G |
获得内存缓冲区的内容,并追加到当前模板块文本的后面 |
l |
列表不能打印字符的清单 |
n |
读取下一个输入行,用下一个命令处理新的行而不是用第一个命令 |
N |
追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码 |
p |
打印模板块的行。 P(大写) 打印模板块的第一行 |
q |
退出Sed |
b lable |
分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾 |
r file |
从file中读行 |
t label |
if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾 |
T label |
错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾 |
w file |
写并追加模板块到file末尾 |
W file |
写并追加模板块的第一行到file末尾 |
! |
表示后面的命令对所有没有被选定的行发生作用 |
= |
打印当前行号 |
# |
把注释扩展到下一个换行符以前 |
标记 |
作用 |
g |
表示行内全面替换 |
p |
表示打印行 |
w |
表示把行写入一个文件 |
x |
表示互换模板块中的文本和缓冲区中的文本 |
y |
表示把一个字符翻译为另外的字符(但是不用于正则表达式) |
\1 |
子串匹配标记 |
& |
已匹配字符串标记 |
字符集 |
作用 |
^ |
匹配行开始,如:/^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 |
< |
匹配单词的开始,如:/\ |
x |
重复字符x,m次,如:/0{5}/匹配包含5个0的行 |
x |
重复字符x,至少m次,如:/0{5,}/匹配至少有5个0的行 |
x |
重复字符x,至少m次,不多于n次,如:/0{5,10}/匹配5~10个0的行 |
实际应用
替换
sed 's/frost/frosts' forst.txt
关注公众号,随时获取最新资讯
细节决定成败!
个人愚见,如有不对,恳请斧正!