sed
sed命令是一个面向字符流的非交互式编辑器,按行来处理文本内容。在shell中,使用sed来批量修改文本内容是非常方便的。
1、sed的工作原理
sed 把每一行都存在临时缓存区中,对这个副本进行编辑,所以不会修改或破坏源文件。具体过程如下:
1)sed 把当前正在处理的行保存在一个临时缓存区中,这个缓存区称为“模式空间”或“临时缓冲”。
2)sed 对模式空间中的行后处理完毕后,就把该行发送到屏幕上(除非之前有命令删除这一行或取消打印操作)。
3)sed处理完输入文件的最后一行后, sed 便结束运行。
2、sed命令详解
2.1、sed命令的语法格式
sed的命令格式
sed [option] 'sed command'filename
sed的脚本格式
sed [option] -f 'sed script'filename
2.2、sed命令的选项(option)
-n :使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN 的数据一般都会被列出到终端上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
-e :多重编辑,且命令顺序会影响结果
-f :直接将 sed 的动作写在一个文件内, -f filename 则可以运行 filename 内的 sed 动作;
-r :sed 的动作支持的是延伸型正规表示法的语法。(默认是基础正规表示法语法)
-i :直接修改读取的文件内容,而不是输出到终端。
2.3、sed定位文本的方式
2.4、sed操作命令(command)
2.5、替换标志
2.6、sed的正则表达式
2.7、字符集
2.8、sed实例
# {}的应用
sed -n '1,4{=;p}' passwd
# a\的应用
sed ‘/pattern/a new_str’file # 在匹配模式的下一行新,增str
sed ‘1a new_str‘ file # 在第1行后,新增str
# !的应用
过滤#注释行和空格行
sed –n ‘/#/!{/$/!p}’file
l /^#/!:打印除了#开头的行
l {/^$/!p}:打印除了空格行
# -e 的应用
删除#注释行和空行。有时-e的不同顺序,会造成不同结果。比如 -e ’1a’–e ‘2a’
sed –e ‘/^#/d’-e ‘/^$/d’ file
将hello所在行的END替换为tail
sed –i ‘/hello/s@END@tail@#’
l @:地址定界符,还可以是/,#等其他特殊字符
# ()和&
将目录下的.txt文件批量命名为.sh文件
find . –name ‘.txt’ | sed –re ‘s#(.).txt#mv & \1.sh#e’
l (.*).txt:查找的文件,对应&
l (.*):分组,对应\1,多个括号就依次对应\2,\3,…
l e:执行mv命令
# <>
删除文件中含有you这个单词的行。\必须加
sed ‘/<you>/d’file
3、参考文档
linux sed命令详解(推荐) (http://www.jb51.net/article/111306.htm)
linux命令总结sed命令详解 (https://www.cnblogs.com/ginvip/p/6376049.html)