sed是一种在线行编辑器,一次处理一行。工作时,把当前处理的行放到“模式空间”中进行编辑,编辑完成后把内容输送至屏幕。
语法:sed [OPTION]…{script}…[input file]
选项:
-r:支持正则表达式
-n:静默模式,不显示内容
-e: script1 -e script2 -e script3:指定多脚本运行
-f /path/to/script_file:从指定的文件中读取脚本并运行
-i: 直接修改源文件
命令:
d: 删除模式空间中的行;
=:显示行号;
a \text:附加text
i \text:插入text,支持\n实现多行插入;
c \text:用text替换匹配到的行;
p: 打印模式空间中的行;
s/regexp/replacement/:替换由regexp所匹配到的内容为replacement;
g: 全局替换;
w /path/to/somefile:把指定的内容另存至/path/to/somefile路径所指定的文件中;
r /path/from/somefile:在文件的指定位置插入另一个文件的所有内容,完成文件合并
正则:
字符匹配:., [], [^]
次数匹配:*, \?, \+, \{m,n\}, \{n\}
位置锚定:^, $, \<, \>
分组及引用:\(\), \1, \2, ...
多选一:a|b|c
定界:
#: 指定行;
$: 最后一行;
/regexp/:任何能够被regexp所匹配到的行;
\%regexp%:同上,只不过换作%为regexp边界符;
/regexp/| :
\%regexp%| :匹配时忽略字符大小写;
startline,endline:
#,/regexp/:从#行开始,到第一次被/regexp/所匹配到的行结束,中间的所有行;
#,#
/regexp1/,/regexp2/:从第一次被/regexp1/匹配到的行开始,到第一次被/regexp2/匹配到的行结束,中间的所有行;
#,+n:从#行开始,一直到向下的n行;
first~step:指定起始行,以及步长;
1~2,2~2
高级命令:
h:用模式空间中的内容覆盖保持空间的内容;
H:把模式空间中的内容追加至保持空间中内容的后面;
g:从保持空间中取到其内容,并将其覆盖模式空间中的内容;
G:从保持空间中取到其内容,并将其追加在模式空间中的内容的后面;
x:把保持空间和模式空间中的进行交换;
n:读取匹配到的行的下一行至模式空间;(会覆盖模式空间中的原有内容);
N:读取匹配到的行的下一行至模式空间,追加在模式空间中原有内容的后面;
d:删除模式空间中的内容;
D:删除多行模式空间中的首行;
注意:命令功能可使用!取反;分号可用于分隔脚本;
练习:
1.删除/root/file文件中所有行的行首的空白字符
[[email protected] ~]# cat file && cat file |wc -l
aaaaaaaaaaaaaaaaa
bbbbbbbbbbbbbbbb
cccccccccccccccc
2. 删除/etc/fstab文件中所有以#开头,后跟至少一个空白字符的行的行首的#和空白字符
[[email protected] ~]# sed ‘s/^#[[:space:]]\+//‘ /etc/fstab
#
/etc/fstab
Created by anaconda on Wed Aug 26 23:57:24 2015
#
Accessible filesystems, by reference, are maintained under ‘/dev/disk‘
See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
/dev/mapper/VolGroup-lv_root / ext4 defaults 1 1
UUID=ccfe9f33-b5da-48b1-821b-b3bec206147b /boot ext4 defaults 1 2
/dev/mapper/VolGroup-lv_swap swap swap defaults 0 0
tmpfs /dev/shm tmpfs defaults 0 0
devpts /dev/pts devpts gid=5,mode=620 0 0
sysfs /sys sysfs defaults 0 0
proc /proc proc defaults 0 0
3. 只查看/etc/fstab文件的第1行到第5行
[[email protected] ~]# sed -n ‘1,5p‘ /etc/fstab
#
# /etc/fstab
# Created by anaconda on Wed Aug 26 23:57:24 2015
#
4.删除文件中包含“my”的行到包含“you”的行之间的行
[[email protected] ~]# cat file
this is my test line
how are you
hello
how are you tom
my
aaaaaaaaaaaaa
you
[[email protected] ~]# sed ‘/my/,/you/d‘ file
hello
how are you tom
5.查询包含“you”的所有行
[[email protected] ~]# sed -n ‘/you/p‘ file
how are you
how are you tom
you
6.在文件中每行后面添加空行
[[email protected] ~]# sed ‘G‘ file
this is my test line
how are you
hello
how are you tom
my
aaaaaaaaaaaaa
you
7. 保证指定的文件每一行后方有且只有一个空白行
[[email protected] ~]# sed ‘/^$/d;G‘ file
this is my test line
how are you
hello
how are you tom
my
aaaaaaaaaaaaa
you
8.打印奇数行
[[email protected] ~]# sed -n ‘1~2p‘ file
1,this is my test line
3,hello
5,my
7,you