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/' file1sed -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.comsed '$a xyz=100' file1 最后一行追加sed -i '2,4s/.*/abc/' file1 第2到4行之间的所有换成abcecho "30%" | sed 's/%//' 去除%号sed '/localhost/a ds.com' file1 匹配localhost的行加入ds.commandssed '/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为ROOTsed 's/root/ROOT/2' file1sed '/tom/s/jerry/mike/g' file1 将匹配到tom的行中的Jerry换成mikeecho "ab/c def" | sed 's/ab\/c/xyz/' 替换ab/c/ 为xyzecho "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' file1sed 's/localhost/www/; s/127/192/' file1sed -e '1,3d' -e 's/tom/jerry/' file1& 保存查找串以便在替换串中引用sed 's/tom/&jerry/' file1范围匹配sed '/abc/,/xyz/s/tom/jerry/' file1 最先匹配到的abc到最先匹配到的xyzsed '/tom/,/jerry/d' file1sed -n '/abc/,/xyz/p' file1sed '1,/tom/d' file1 从第一行到第一个匹配tomsecurity = share smb.confhosts allow smb.conf/etc/sysconfig/selinuxUseDNS no /etc/ssh/sshd_configsed -ri "/IPADDR/s/[0-9.]+/$ip/" ifcfg-eth0
参考文献