格式:
sed [OPTION]... {script-only-if-no-other-script} [input-file]...
sed [OPTION]... ‘地址定界+[高级]编辑命令’ file
常用选择:
i :修改内容
i.bak :先备份,然后再修改内容
r :支持正则表达式
e :支持多点编辑
n :不输出模式空间内容到屏幕,即不自动打印
'地址定界+[高级]编辑命令'
地址定界
1.不给地址:
对全文进行处理
2.单地址:
#:指定的行 , $:最后一行
/pattern/:被此处模式所能够匹配到的每一行
3.地址范围
#,#
#,+#
/pat1/,/pat2/
#,/pat1/
4. ~:步进
1~2 奇数行
2~2 偶数行
编辑命令
d:删除模式空间匹配的行,并立即启用下一轮循环
p:打印当前模式空间内容,追加到默认输出之后
a[]text:在指定行后面追加文本,支持使用
实现多行追加
i[]text:在行前插入文本
c[]text:替换行为单行或多行文件
w /path/somefile:保存模式匹配的行至指定文件
r /path/somefile:读取指定文件的文本至模式空间中匹配到的行后
=:为模式空间中的行打印行号 !:模式空间中匹配行取反处理
高级编辑命令 P:打印模式空间开端至
内容,并追加到默认输出之前
h:把模式空间中的内容覆盖至保持空间中 H:把模式空间中的内容追加至保持空间中
g:从保持空间取出数据覆盖至模式空间 G:从保持空间取出数据追加至模式空间
x:把模式空间中的内容与保持空间中的内容进行交换
n:读取匹配到的行的下一行覆盖至模式空间
N:读取匹配到的行的下一行追加至模式空间
d:删除模式空间中的行
D:如果模式空间包含换行符,则删除知道第一个换行符的模式空间中的文本, 并不会读取新的输入行,而使用合成的模式空间重新启动循环。如果模式空间不包含换行符,则会像发 出d命令那样启动正常的新循环
基本正则模式匹配
匹配字符:
. :任意一个字符。
[abc] :表示匹配一个字符
[a-Z] :表示匹配一个字符
[^123] :匹配一个字符,这个字符是除了1、2、3以外的所有字符。
对于一些常用的字符集,系统做了定义:
[a-Z] 等价于 [[:alpha:]]
[0-9] 等价于 [[:digit:]]
[a-Z0-9] 等价于 [[:alnum:]]
tab,space 等空白字符 [[:space:]]
[A-Z] 等价于 [[:upper:]]
[a-z] 等价于 [[:lower:]]
标点符号 [[:punct:]]
匹配次数:
{m,n} :匹配其前面出现的字符至少m次,至多n次。
? :匹配其前面出现的内容0次或1次,等价于{0,1}。
* :匹配其前面出现的内容任意次,等价于{0,},所以 ".*" 表述任意字符任意次,即无论什么内容全部匹配。
位置锚定:
^ :锚定行首
$ :锚定行尾。技巧:"^$"用于匹配空白行。
或<:锚定单词的词首。如"like"不会匹配alike,但是会匹配liker
或>:锚定单词的词尾。如"like"不会匹配alike和liker,只会匹配like
B :与作用相反。
分组及引用:
(string) :将string作为一个整体方便后面引用
1 :引用第1个左括号及其对应的右括号所匹配的内容。
2 :引用第2个左括号及其对应的右括号所匹配的内容。
:引用第n个左括号及其对应的右括号所匹配的内容。
扩展正则模式匹配
匹配字符:
跟基本正则用法一样
匹配次数:
{m,n} :匹配其前面出现的字符至少m次,至多n次。
? :匹配其前面出现的内容0次或1次,等价于{0,1}。
* :匹配其前面出现的内容任意次,等价于{0,},所以 ".*" 表述任意字符任意次,即无论什么内容全部匹配。
+:匹配前面出现的内容1次或1次以上
位置锚定:
跟基本正则用法一样
分组及引用:
(string) :将string作为一个整体方便后面引用
1 :引用第1个左括号及其对应的右括号所匹配的内容。
2 :引用第2个左括号及其对应的右括号所匹配的内容.
:引用第n个左括号及其对应的右括号所匹配的内容。
扩展增用法:
str | num:匹配 str 或 num 内容
例题
1.删除/etc/grub2.cfg文件中所有以空白开头的行行首的空白字符
[root@cloud ~]# sed -r "/^[[:space:]]*$/d" /etc/grub2.cfg
2.删除/etc/fstab文件中不以#开头,后面至少跟一个空白字符的行的行首的和空白字符
[root@cloud ~]# sed -r "/^# *|^$/d" /etc/fstab
3.在/etc/fstab文件中不以#开头的行的行首增加#号
[root@cloud ~]# sed -r -n "/^[^#]/s/(.*)/#1/p" /etc/fstab
4.处理/etc/fstab路径使用sed命令取出其目录和基名
[root@cloud ~]# echo /etc/fstab | sed -r "s@(.*/)(.*$)@2@"
5.利用sed取出ifconfig命令中本机的IPv4地址
[root@cloud ~]# ifconfig eth0 | sed -r -n "s/.*inet (.*) net.*/1/p"
6.统计centos安装光盘中Package目录下的所有rpm文件的以. 分割倒数第二个字段的重复次数
[root@cloud ~]# mount /dev/cdrom /opt/dvd [root@cloud ~]# ls /opt/dvd/Packages/ | sed -r "s/.rpm$//" | sed -r "s/.*.(.*)/1/" | sort | uniq -c [root@cloud ~]# ls /opt/dvd/Packages/ | sed -r "s/.*.(.*).rpm/1/" | sort | uniq -c
7.将文本文件的n和n+1行合并为一行,n为奇数行
[root@cloud ~]# seq 10|xargs -n2 [root@cloud ~]# seq 10|sed 'N;s/ / /'