$ cat file
aa
88
bb
88
88
cc
88
88
#替换第一个88为--
sed ':a;N;$!ba;s/88/--/' file
sed ':a;N;$!ba;s/88/--/1' file
#替换第n个88为--
sed ':a;N;$!ba;s/88/--/n' file
:a
N
$!ba
构建一个循环将整个文件逐行添加至pattern space
用Next命令将一个新的输入行追加至pattern space的当前行,使用Next命令时候最后一行要
不执行Next命令
最后一行不跳转至a,其他都跳转至a
s/88/--/ 匹配到第一个88然后进行替换
sed '0,/88/s//--/' file
0,/88/ 0行到第一个88
s//--/ 替换pattern space内的内容为--
函数参数N
函数参数s
[address1,[address2]]s/pattern/replacement/[flag]
replacement特殊字符
&: 代表其前pattern字符串
sed 's/test/& my car/' file
将test替换成test my car
\n: 代表pattern中被第n个\( \)所括起来的字符串
sed 's/\(test\) \(my\) \(car\)/[\2 \3 \1]' file
可以按照任意顺序回调保存的子串,并且可以多次调用
\: 转义特殊符号,或者用它来代表新行
flag: 主要用来控制一些替换情况
g: 全局替换
十进制数m时:替换行内第m个符合的字符串
p: 代表替换第一个符合pattern的字符串后,将数据输出标准输出文件
w wfile: 代表替换第一个符合pattern的字符串后,输出到wfile内
delimiter: 在"/pattern/replace/[flag]"中"/"被当成一delimiter。除了空白
换行之外,使用者可以用任何字符作为delimiter
s#/usr#/usr1#g