sed中的正则匹配
1个回答
展开全部
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]。
欢迎关注!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询