现在有一个文件里面有多行相似内容
例如
test.txt
zhangsan=zheren,feichang,youqian
lisi=zheren,feichang,youqian
laowang=zheren,feichang,youqian
现在我们要指定删除包含字符串(lisi)这一行的字符串(feichang)
sed -r ‘s@lisi(.)feichang(.)@lisi\1\2@’ test.txt
如上图显示,这样lisi这一行的(feichang)就被删掉了
当然这样匹配其他位置的也可以比如删除字符串(zhren)
这里有一个简单的例子:
$ echo ‘abcabcabc’ | sed ‘s/(ab)c/\1/’
ababcabc
$ echo ‘abcabcabc’ | sed ‘s/(ab)c/\1/g’
ababab
$ echo ‘abcabcabc’ | sed ‘s/(ab)(c)/\1d\2/g’
abdcabdcabdc
在第一个命令中,只有第一个匹配受到影响。在第二个命令中,每个匹配都会受到影响。在这两种情况下,\1指的是由转义括号捕获的字符。
在第三个命令中,指定了两个捕获组。他们通过使用\1和引用\2。最多可以使用九个捕获组。
除了g(全局)运算符(或没有它,第一次匹配)之外,你可以指定特定的匹配项:
$ echo ‘aaaaaa’ | sed ‘s/a/A/4’
aaaAaa
(…)将捕获在parens内指定的字符,\1并将用于引用第一个匹配,这是正则表达式的一部分。