基本正则表达式小结
前面学习的正则表达式基本上都是基础正则表达式,现总结如下:
- #################常用符号#################
- . 表示任意单个字符。
- * 表示前面的字符连续出现任意次,包括0次。
- .* 表示任意长度的任意字符,与通配符中的*的意思相同。
- \ 表示转义符,当与正则表达式中的符号结合时表示符号本身。
- [ ]表示匹配指定范围内的任意单个字符。
- [^ ]表示匹配指定范围外的任意单个字符。
- #################单个字符匹配相关#################
- [[:alpha:]] 表示任意大小写字母。
- [[:lower:]] 表示任意小写字母。
- [[:upper:]] 表示任意大写字母。
- [[:digit:]] 表示0到9之间的任意单个数字(包括0和9)。
- [[:alnum:]] 表示任意数字或字母。
- [[:space:]] 表示任意空白字符,包括"空格"、"tab键"等。
- [[:punct:]] 表示任意标点符号。
- [^[:alpha:]] 表示单个非字母字符。
- [^[:lower:]] 表示单个非小写字母字符。
- [^[:upper:]] 表示单个非大写字母字符。
- [^[:digit:]] 表示单个非数字字符。
- [^[:alnum:]] 表示单个非数字非字母字符。
- [^[:space:]] 表示单个非空白字符。
- [^[:punct:]] 表示单个非标点符号字符。
- [0-9]与[[:digit:]]等效。
- [a-z]与[[:lower:]]等效。
- [A-Z]与[[:upper:]]等效。
- [a-zA-Z]与[[:alpha:]]等效。
- [a-zA-Z0-9]与[[:alnum:]]等效。
- [^0-9]与[^[:digit:]]等效。
- [^a-z]与[^[:lower:]]等效。
- [^A-Z]与[^[:upper:]]等效
- [^a-zA-Z]与[^[:alpha:]]等效
- [^a-zA-Z0-9]与[^[:alnum:]]等效
- #简短格式并非所有正则表达式解析器都可以识别。
- \d 表示任意单个0到9的数字。
- \D 表示任意单个非数字字符。
- \t 表示匹配单个横向制表符(相当于一个tab键)。
- \s表示匹配单个空白字符,包括"空格","tab制表符"等。
- \S表示匹配单个非空白字符。
- #################次数匹配相关#################
- \? 表示匹配其前面的字符0或1次
- \+ 表示匹配其前面的字符至少1次,或者连续多次,连续次数上不封顶。
- \{n\} 表示前面的字符连续出现n次,将会被匹配到。
- \{x,y\} 表示之前的字符至少连续出现x次,最多连续出现y次,都能被匹配到,换句话说,只要之前的字符连续出现的次数在x与y之间,即可被匹配到。
- \{,n\} 表示之前的字符连续出现至多n次,最少0次,都会陪匹配到。
- \{n,\}表示之前的字符连续出现至少n次,才会被匹配到。
- #################位置边界匹配相关#################
- ^:表示锚定行首,此字符后面的任意内容必须出现在行首,才能匹配。
- $:表示锚定行尾,此字符前面的任意内容必须出现在行尾,才能匹配。
- ^$:表示匹配空行,这里所描述的空行表示"回车",而"空格"或"tab"等都不能算作此处所描述的空行。
- ^abc$:表示abc独占一行时,会被匹配到。
- \<或者\b :匹配单词边界,表示锚定词首,其后面的字符必须作为单词首部出现。
- \>或者\b :匹配单词边界,表示锚定词尾,其前面的字符必须作为单词尾部出现。
- \B:匹配非单词边界,与\b正好相反。
- #################分组与后向引用#################
- \( \) 表示分组,我们可以将其中的内容当做一个整体,分组可以嵌套。
- \(ab\) 表示将ab当做一个整体去处理。
- \1 表示引用整个表达式中第1个分组中的正则匹配到的结果。
- \2 表示引用整个表达式中第2个分组中的正则匹配到的结果。
如果想要查看ifconfig命令中IPV4格式的IP地址,应该怎么办呢?
可以使用正则表达式如下:
[root@localhost135 ~]# ifconfig | grep -n "\([0-9]\{1,3\}\.\)\{3\}[0-9]\{1,3\}"
2: inet 192.168.148.135 netmask 255.255.255.0 broadcast 192.168.148.255
11: inet 127.0.0.1 netmask 255.0.0.0
20: inet 192.168.122.1 netmask 255.255.255.0 broadcast 192.168.122.255
[root@localhost135 ~]
上述正则表达式可以分成三部分去理解。