1.常用符号
- . 表示任意单个字符
- * 表示前面的字符连续出现任意次,包括0次
- .*表示任意长度的任意字符,与通配符中*的意思相同
- \表示转义符,当与正则表达式中的符合结合时表示符号本身
- [ ]表示匹配指定范围内的任意单个字符
- [^ ]表示匹配指定范围外的任意单个字符
2.单个字符匹配相关
- [[:alpha:]] ,[a-zA-Z]表示任意大小写字母
- [[:lower:]] ,[a-z]表示任意小写字母
- [[:upper:]],[A-Z]表示任意大写字母
- [[:digit:]],[0-9]表示0-9之间的任意单个数字
- [[:alnum:]],[a-zA-Z0-9]表示任意数字或字母
- [[:space:]]表示任意空白字符,包括“空格”,“tab”等
- [[:punct:]] 表示任意标点符号
- [^[:alpha:]],[^a-zA-Z]表示单个非字母字符
- [^[:lower:]],[^a-z]表示单个非小写字母字符
- [^[:upper:]],[^A-Z]表示单个非大写字母字符
- [^[:digit:]],[^0-9]表示单个非数字字符
- [^[:alnum:]],[^a-zA-Z0-9]表示单个非数字非字母字符
- [^[:space:]]表示单个非空白字符
- [^[:punct:]]表示单个非标点符号字符
- #简短格式并非所有正则表达式解析器都可以识别
- \d 表示任意单个0-9的数字
- \D表示任意单个非数字字符
- \t 表示匹配单个横向制表符(相当于一个tab键)
- \s表示匹配单个空白字符,包括“空格”,“tab”
- \S表示匹配单个非空白字符
次数匹配相关
- \? 表示匹配其前面的字符0,1次
- \+ 表示匹配前面的字符至少1次
- \{n\} 表示前面的字符连续出现n次,将会倍匹配到
- \{x,y\}表示之前的字符至少连续出现x次,最多连续出现y次,都能匹配到。
- \{,n\}表示之前的字符连续出现至多n次,最少0次,都会被匹配到。
- \{n,\}表示之前的字符连续出现至少n次,或更多次。
位置边界匹配相关
- ^ 表示锚定行首,此字符后面的任意内容必须出现在行首。
- $表示锚定行尾,此字符后面的任意内容必须出现在行尾。
- ^$ 表示匹配空行,这里描述的空行表示“回车”
- ^abc$表示abc独占一行
- \<和\b匹配单词边界,表示锚定词首,其后面的字符必须作为单词首部出现
- \>和\b匹配单词边界,表示锚定词尾,其前面的字符必须作为单词尾部出现。
- \B匹配非单词边界。
分组与后向引用
- \( \)表示分组,我们可以将其中的内容当作一个整体,分组可以嵌套。
- \(ab\)表示将ab当作一个整体去处理
- \1表示引用整个表达式中第1个分组中的正则匹配到的结果
- \2表示引用整个表达式中第1个分组中的正则匹配到的结果
扩展正则表达式:
基本正则表达式与扩展正则表达式大部分用法都完全相同。grep命令默认只支持基本正则表达式,如果想要让grep支持扩展的正则表达式,则需要使用“-E”选项,示例如下:

扩展正则表达式中,还有一个|,用法如下:

420

被折叠的 条评论
为什么被折叠?



