首页 > 其他 > 详细

sed 命令的详解

时间:2014-04-09 16:28:50      阅读:493      评论:0      收藏:0      [点我收藏+]

sed命令的原理:     

         首先sed把当前正在处理的行保存在一个临时缓存区中(也称为模式空间),然后处理临时缓冲区中的行,完成后把该行发送到屏幕上。sed每处理完一行就将其从临时缓冲区删除,然后将下一行读入,进行处理和显示。处理完输入文件的最后一行后,sed便结束运行。sed把每一行都存在临时缓冲区中,对这个副本进行编辑,所以不会修改原文件。 

sed命令的参数
    
命令功能
a\

在当前行后添加一行或多行。多行时除最后一行外,每行末尾需用“\”续行

c\用此符号后的新文本替换当前行中的文本。多行时除最后一行外,每行末尾需用"\"续行
i\在当前行之前插入文本。多行时除最后一行外,每行末尾需用"\"续行
d删除行
h把模式空间里的内容复制到暂存缓冲区
H把模式空间里的内容追加到暂存缓冲区
g把暂存缓冲区里的内容复制到模式空间,覆盖原有的内容
G把暂存缓冲区的内容追加到模式空间里,追加在原有内容的后面
l列出非打印字符
p打印行
n读入下一输入行,并从下一条命令而不是第一条命令开始对其的处理
q结束或退出sed
r从文件中读取输入行
!对所选行以外的所有行应用命令
s用一个字符串替换另一个
g在行内进行全局替换
w将所选的行写入文件
x交换暂存缓冲区与模式空间的内容
y将字符替换为另一字符(不能对正则表达式使用y命令)

 sed选项

选项功能
-e进行多项编辑,即对输入行应用多条sed命令时使用
-n取消默认的输出
-f指定sed脚本的文件名
sed 命令的正则表达式
5.正则表达式元字符
         与grep一样,sed也支持特殊元字符,来进行模式查找、替换。不同的是,sed使用的正则表达式是括在斜杠线"/"之间的模式。
如果要把正则表达式分隔符"/"改为另一个字符,比如o,只要在这个字符前加一个反斜线,在字符后跟上正则表达式,再跟上这个字符即可。例如:sed -n ‘\o^Myop‘ datafile
元字符功能示例
^行首定位符/^my/ 匹配所有以my开头的行
$行尾定位符/my$/ 匹配所有以my结尾的行
.匹配除换行符以外的单个字符/m..y/ 匹配包含字母m,后跟两个任意字符,再跟字母y的行
*匹配零个或多个前导字符/my*/ 匹配包含字母m,后跟零个或多个y字母的行
[]匹配指定字符组内的任一字符/[Mm]y/ 匹配包含My或my的行
[^]匹配不在指定字符组内的任一字符/[^Mm]y/ 匹配包含y,但y之前的那个字符不是M或m的行
\(..\)保存已匹配的字符1,20s/\(you\)self/\1r/ 标记元字符之间的模式,并将其保存为标签1,之后可以使用\1来引用它。最多可以定义9个标签,从左边开始编号,最左边的是第一个。此例中,对第1到第20行进行处理,you被保存为标签1,如果发现youself,则替换为your。
&保存查找串以便在替换串中引用s/my/**&**/ 符号&代表查找串。my将被替换为**my**
\<词首定位符/\<my/ 匹配包含以my开头的单词的行
\>词尾定位符/my\>/ 匹配包含以my结尾的单词的行
x\{m\}连续m个x/9\{5\}/ 匹配包含连续5个9的行
x\{m,\}至少m个x/9\{5,\}/ 匹配包含至少连续5个9的行
x\{m,n\}至少m个,但不超过n个x/9\{5,7\}/ 匹配包含连续5到7个9的行
sed命令的练习
 
sed ‘/abc/p‘ file1
读取file1的第一行到pattern space(临时缓冲区, 内存)
对pattern space中的这一行进行/abc/p操作
将pattern space中的这一行打印出来
清空pattern space
读取file1的下一行到pattern space
......
ssh root@192.168.0.254 sed -i ‘s/abc/def/‘ file1
sed -n ‘5p‘ file1  打印第5行
sed -n ‘1,5p‘ file1 打印第1到5行
sed -n ‘$p‘ file1    打印最后一行
sed -n ‘/^root/p‘ file1  打印匹配以root开头的行
sed ‘3i ds.com‘ file1  在第三行插入ds.com
sed ‘$a xyz=100‘ file1     最后一行追加
sed -i ‘2,4s/.*/abc/‘ file1        第2到4行之间的所有换成abc
echo "30%" | sed ‘s/%//‘      去除%号
sed ‘/localhost/a ds.com‘ file1   匹配localhost的行加入ds.commands
sed ‘/root/c aixocm‘ file1   用aixocm 替换匹配root的行中的内容
sed ‘/abc/d‘ file1   删除匹配abc的行
sed ‘/abc/!d‘ file1  不删除匹配abc的行
sed ‘3d‘ file1      删除第3行
sed ‘1,3d‘ file1    删除第1到第3行
sed ‘3,$d‘ file1     删除第3到最后一行
sed ‘/^$/d‘ file1      删除空白行
sed ‘/^\s*$/d‘ file1    如果是制表符造成的空白行,用这个方式删除
sed ‘s/root/ROOT/‘ file1     将root替换成ROOT(只替换匹配的第一个root)
sed ‘s/root/ROOT/g‘ file1    替换全部的root为ROOT
sed ‘s/root/ROOT/2‘ file1
sed ‘/tom/s/jerry/mike/g‘ file1    将匹配到tom的行中的Jerry换成mike
echo "ab/c def" | sed ‘s/ab\/c/xyz/‘  替换ab/c/  为xyz
echo "a b c" | sed ‘s/ //g‘   删除a b c 之间的空白
引用变量
var1="root"
sed "/$var1/c aixocm" file1
行首加#
sed ‘/ADDR/s/^/#/‘ file1
去行首#
sed ‘/ADDR/s/^#//‘ file1
多次操作
sed ‘5s/abc/xxx/; 9s/abc/yyy/g‘ file1
sed ‘s/localhost/www/; s/127/192/‘ file1
sed -e ‘1,3d‘ -e ‘s/tom/jerry/‘ file1
& 保存查找串以便在替换串中引用
sed ‘s/tom/&jerry/‘ file1
范围匹配
sed ‘/abc/,/xyz/s/tom/jerry/‘ file1 最先匹配到的abc到最先匹配到的xyz
sed ‘/tom/,/jerry/d‘ file1
sed -n ‘/abc/,/xyz/p‘ file1
sed ‘1,/tom/d‘ file1 从第一行到第一个匹配tom
security = share smb.conf
hosts allow smb.conf
/etc/sysconfig/selinux
UseDNS no /etc/ssh/sshd_config
sed -ri "/IPADDR/s/[0-9.]+/$ip/" ifcfg-eth0

 

参考文献
 

 

本文出自 “穷途--初心” 博客,请务必保留此出处http://aixocm.blog.51cto.com/4208464/1392752

sed 命令的详解,布布扣,bubuko.com

sed 命令的详解

原文:http://aixocm.blog.51cto.com/4208464/1392752

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!