【Linux】shell学习之sed

sed替换命令

使用该命令,可以将特定字符串或匹配的规则表达式用另一个字符串替换。

 

sed 's/88/--/' filename    将filename每行第一次出现的88用字符串--替换,然后将该文件内容输出到标准输出
sed 's/88/--/g' filename    附加g选项告诉sed执行全局替换

匹配第N个进行替换

N=1

sed '0,/88/s//--/' filename    只匹配到第一个88为止
sed ':a;N;$!ba;s/88/--/' filename

第二个命令

  1. :a 创建一个label a
  2. N 将下一行读入到pattern space
  3. $! 如果不是最后一行,ba跳转到label a处
  4. s/a/A/ 替换a为A,只替换一次

步骤1-3(即:a;N;$!ba;)就是为了将filename全部内容读到模式空间中,然后再进行替换,这样替换就只会做一次。

N=3

第一个命令叫打点记数法,因为sed没有var++之类的操作来记数。

第二个命令和上面是一样的原理,全部读入文本后统一替换第3个匹配的内容。

N=last

第一个命令,没匹配到 / 88/ 的内容就读取下一行,然后 ba 跳转去开始处,如果读取到88的行呢,就执行后面的 P;D 组合,D也有循环功能,一直把匹配 88 内容的第一行打印,删除,直到不匹配/ 88/(因为换行符已经被打印出去了,所以不再会匹配到 88),这时候才继续往下读,如果又读到88的行,那么又执行P;D循环,同上操作。一直到匹配到最后一个88的行,继续读取到末行时执行替换,N 因为没有下一行可读,所以会自动中止命令,因为没有 -n 参数会打印 pattern space 里的内容到屏幕,所以就不会再执行后面的 ba 避免了死循环,这样的用法只存在于 GNU sed ,大家注意。所以这整个流程只会替换最后一个88。
第二个命令和上面的一样,也是全部读进 pattern space 里,最后利用正则的贪婪替换掉最后一个88。

注意两者区别。

原文地址:https://www.cnblogs.com/wayne793377164/p/7095651.html