作用 :用于解决文本的流编辑器.
命令格局
sed Options '[Address]Command' InputFile
对输出文件 InputFile 中的每行执行给定的命令 Command.
如果指定了地址 Address,则只对符合条件的文本行执行 Command 命令.
罕用选项
-i
: 原地批改,会扭转源文件中的内容.-n
: 处理过程中,不要输入正在解决的文本行.-r
: 应用正则表达式扩大.-f File
: 从文件 File 中读取 sed 命令.
地址
n
: 第 n 行.
[ming@localhost test]$ cat data.txt
a
a123
aa456
aaa789
b123
bb456
bbb789
[ming@localhost test]$ sed -n '2p' data.txt
a123
p
: 打印行.
$
: 最初一行.
[ming@localhost test]$ sed -n '$p' data.txt
bbb789
/regexp/
: 匹配指定正则表达式的行.
[ming@localhost test]$ sed -nr '/a+/p' data.txt
a
a123
aa456
aaa789
[ming@localhost test]$ sed -nr '/a{2,}/p' data.txt
aa456
aaa789
n~m
: 从第 n 行开始,每 m 行便执行给定的命令.
[ming@localhost test]$ cat data.txt
a
a123
aa456
aaa789
b123
bb456
bbb789
[ming@localhost test]$ sed -n '1~2p' data.txt
a
aa456
b123
bbb789
addr1,addr2
: 从 addr1 开始,到 addr2 完结,包含首尾.
[ming@localhost test]$ sed -n '2,4p' data.txt
a123
aa456
aaa789
[ming@localhost test]$ sed -n '/123/,/123/p' data.txt
a123
aa456
aaa789
b123
addr,+n
: 从 addr 开始(包含),直到往后 n 行.
[ming@localhost test]$ sed -n '2,+2p' data.txt
a123
aa456
aaa789
[ming@localhost test]$ sed -nr '/a{3}/,+2p' data.txt
aaa789
b123
bb456
1. 替换 : s/regexp/replacement/
替换每行第一处匹配的中央:将 a 替换成 A
[ming@localhost test]$ sed 's/a/A/' data.txt
A
A123
Aa456
Aaa789
b123
bb456
bbb789
替换每行第 2 处匹配的中央:
[ming@localhost test]$ sed 's/a/A/2' data.txt
a
a123
aA456
aAa789
b123
bb456
bbb789
替换每行所有匹配的中央:g
[ming@localhost test]$ sed 's/a/A/g' data.txt
A
A123
AA456
AAA789
b123
bb456
bbb789
应用正则表达式:
[ming@localhost test]$ sed -r 's/[0-9]+/Number/' data.txt
a
aNumber
aaNumber
aaaNumber
bNumber
bbNumber
bbbNumber
援用匹配的内容:&
[ming@localhost test]$ sed -r 's/[0-9]+/<&>/' data.txt
a
a<123>
aa<456>
aaa<789>
b<123>
bb<456>
bbb<789>
援用匹配的分组:\n
[ming@localhost test]$ sed -r 's/a{1,3}([0-9]+)/<\1>/' data.txt
a
<123>
<456>
<789>
b123
bb456
bbb789
\n
: 援用第 n 个分组.
2. 删除行 : d
[ming@localhost test]$ sed '/a\+/d' data.txt
b123
bb456
bbb789
3. 插入行 : i\
或 a\
插到指定行之前:i\
[ming@localhost test]$ sed -r '/a+/i\line1\n\line2' data.txt
line1
line2
a
line1
line2
a123
line1
line2
aa456
line1
line2
aaa789
b123
bb456
bbb789
插到指定行之后:a\
[ming@localhost test]$ sed -r '/a+/a\line1' data.txt
a
line1
a123
line1
aa456
line1
aaa789
line1
b123
bb456
bbb789
4. 替换行 : c\
[ming@localhost test]$ sed -r '/a+/c\line has a' data.txt
line has a
line has a
line has a
line has a
b123
bb456
bbb789
5. 映射 : y/source/dest/
[ming@localhost test]$ sed 'y/ab/AB/' data.txt
A
A123
AA456
AAA789
B123
BB456
BBB789
6. 读写文件
将指定的行写入指定的文件:w File
[ming@localhost test]$ sed -nr '/a+/w a.txt' data.txt
[ming@localhost test]$ cat a.txt
a
a123
aa456
aaa789
读取文件内容,并将其插到指定行之后:r File
[ming@localhost test]$ cat input.txt
----
[ming@localhost test]$ sed -r '/a+/r input.txt' data.txt
a
----
a123
----
aa456
----
aaa789
----
b123
bb456
bbb789
7. 应用变量
[ming@localhost test]$ rpl="NUMBER"
[ming@localhost test]$ sed -r 's/[0-9]+/'"$rpl"'/' data.txt
a
aNUMBER
aaNUMBER
aaaNUMBER
bNUMBER
bbNUMBER
bbbNUMBER
8. 应用脚本文件
[ming@localhost test]$ cat script.sed
/a+/ {
i\a begin
a\a end
}
s/[0-9]+/Number/
[ming@localhost test]$ sed -rf script.sed data.txt
a begin
a
a end
a begin
aNumber
a end
a begin
aaNumber
a end
a begin
aaaNumber
a end
bNumber
bbNumber
bbbNumber