sed中的正则匹配

如题所述

第1个回答  2022-06-15

sed很早就支持正则表达式了,这在文件处理中非常有用,以下列出一些常见用法( GNU SED版本 )。

行首用^表示,行尾用$表示。例如有如下test.txt文件:

如果我们想把其中第一列的Potri.去掉,那么可以:

假如想在最后数字的后面加一列"yes":

(来自 https://wiki.jikexueyuan.com/project/unix/regular-expressions.html )

比较常用的有:

用[]代表这样的列表,比如:

结果输出:
Cat
Hat
[]代表从其中选择一个。

仅输出Bat。

出现不止一次(>= 1): \+
出现0或1次:\?
出现n次:{n}
出现>=n次:{n,}
出现m到n次:{m, n}

注意前后括号{}都需要转义。

或者 | 常与 () 一起使用,注意两者都需要反斜杠\转义。

一些特殊字符比如换行符\n或者回车\r等,匹配的时候在前面再加一个反斜杠转义,如\\r。

匹配上海市电话号码:

匹配ip地址:

值得注意的是,在sed中不支持\d匹配数字,此处须用[0-9]。

欢迎关注!

相似回答