3.2.2.4 文本匹配锚点
Posted avention
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了3.2.2.4 文本匹配锚点相关的知识,希望对你有一定的参考价值。
再介绍两个 mate 字符就能完成整个 BRE 的介绍了。这两个 meta 字符是脱字符号(^)与货币符号($),它们叫做锚点(anchor),因为其用途在限制正则表达式匹配时,真对要被匹配字符串的开始或结尾进行匹配(^在此处的用法与方括号表达式里的完全不同)。假定现在有一串要进行匹配的字:abcABCdefDEF ,以下标列举匹配范例:
正则表达式内锚点的范例
模式
|
是否匹配
|
匹配文本(粗体)/ 匹配失败的理由
|
ABC | 是 | 居中的第4、5及6个字符:abcABCDEFdefDEF |
^ABC | 否 | 限定匹配字符串的起始处 |
def | 是 | 居中的第7、8及9个字符:abcABCDEFdefDEF |
def$ | 否 | 限制匹配字符串的结尾处 |
[[:upper:]]{3} | 是 | 居中的第4、5及6个字符:abcABCDEFdefDEF |
[[:upper:]]{3}$ | 是 | 居中的第10、11及12个字符:abcABCDEFdefDEF |
^[[:alpha:]]{3} | 是 | 起始的第1、2及3个字符:abcABCdefDEF |
^与$也可同时使用,这种情况是将括起来的正则表达式匹配整个字符串(或行)。有时^$这样简易正则表达式也很好用,它可以用来匹配空的字符串或行列。例如在 grep 加上 -v 选项可以用来显示所有不匹配与模式的行,使用上面的做法,便能过滤掉文件里的空行。
cc -E foo.c | grep -v ‘^$‘ > foo.out 预先删除空行
^与$ 仅在BRE的起始与结尾处具有特殊用途。若出现在字符串中间则表示自身。
以上是关于3.2.2.4 文本匹配锚点的主要内容,如果未能解决你的问题,请参考以下文章