在本博客中,"正则表达式"为一系列文章,如果你想要从头学习怎样在Linux中使用正则,可以参考此系列文章,直达链接如下:
在Linux中使用正则表达式
"正则"系列的每篇文章都建立在前文的基础之上,所以,请按照顺序阅读这些文章,否则有可能在阅读中遇到障碍。
写这篇文章的目的就是总结前文中所介绍的"基本正则表达式",并且结合一些实例进行练习,以便我们能够在练习中完全掌握它们。
首先,我们对前文中提到的符号进行总结,总结如下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62
|
#################常用符号################# . 表示任意单个字符。 * 表示前面的字符连续出现任意次,包括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个分组中的正则匹配到的结果。 |
回头看看,似乎我们已经掌握了不少符号,那么,我们能够通过这些符号干嘛呢?我们来动手试试?
比如,我想要从如下文本中找出,哪些人的手机号是以136开头的,我们该怎样做呢?

我们可以使用grep命令,配合如下正则表达式。

可以看到,我们通过上述正则,找到了手机号以136开头的用户,我和金刚狼的手机号都是136打头的。
上述正则中,"136[[:digit:]]\{8\}"表示136后面跟随了8个连续的任意数字,所以,"136[[:digit:]]\{8\}"就表示一个以136开头的11位数字,也就是我们想要找到的"手机号"
但是,如果仅仅使用"136[[:digit:]]\{8\}"这个正则表达式,那么文本中的错误号码也会被匹配到,所以,我们在需要在正则的两侧加上"\b"。
两端的"\b"表示锚定词首与锚定词尾,所以,"\b136[[:digit:]]\{8\}\b"表示一个以136开头的11位数字,并且这11个数字作为一个单独的单词存在。
如果之前每一篇关于正则表达式的文章你都阅读过,并且理解了,那么看懂上述正则应该不是什么难事。这里就不再赘述了。
那么,如果我们想要从ifconfig命令的结果中找出IPV4格式的IP地址,应该怎么办呢?

我们可以使用如下正则表达式。

为了方便理解,我们可以将上述正则表达式拆分成3段去理解,没错,我们把上述正则拆分成红色标注部分,蓝色标注部分,绿色标注部分。
红色部分的正则为"\([0-9]\{1,3\}\.\)",它表示一个最少为1位数字,最多为3位数字的字符串,并且这个字符串后面跟随了一个"点",我们把这个带有点的数字字符串当做一个整体。
蓝色部分的正则为"\{3\}",它表示之前的字符需要连续出现3次,当它与红色部分的正则结合在一起时,表示符合红色部分正则的字符串需要连续出现3次。
绿色部分的正则为"[0-9]\{1,3\}",它表示一个最少为1位数字,最多为3位数字的字符串。
当上述三部分正则结合在一起时,就能表示一个类似IPV4地址的字符串(此处暂不考虑1到254的取值范围)。
其实怎样去写正则表达式,没有一个固定的方法,只要能够正确的排列组合,表达出我们想要表达的意思,匹配到我们想要匹配的字符串,就是正确的写法,你也可以通过自己的想法,写出对应正则表达式。
关于怎样在Linux中使用"基本正则表达式",就总结到这里,之后,我们会介绍怎样在Linux中使用"扩展正则表达式"。
有了基本正则表达式的基础,再去理解扩展正则表达式,绝对很轻松,好了,今天就到这里,希望这篇文章能够帮到你~~~
2020年4月20日 上午11:54 沙发
打卡,博主最帅~
2020年2月3日 下午7:48 板凳
啦啦啦
2019年8月12日 上午8:59 地板
赞一个
2019年7月26日 下午7:40 4楼
[^]描述写错了,是不匹配任意字符。
2019年7月26日 下午7:42 1层
@迈克尔西门庆 我去看错了,你说的是任意外,看来没错。
2019年6月20日 下午8:05 5楼
这是怎么回事?大神帮看看,谢谢!
2019年6月20日 下午8:07 1层
@lee 是不是关键字必须得用引号引上
2020年9月18日 上午11:17 1层
@lee 我推测是grep f* test1 在本目录匹配到了文件名ff,命令就变成了
grep ff test1
2019年5月5日 下午3:59 6楼
膜拜大神!
2018年12月30日 下午1:52 7楼
感谢,我上课一点都听不懂。在这里突然感觉自己都是大神了
2018年9月22日 下午5:25 8楼
2018年9月13日 下午4:25 9楼
滴滴滴~~~~打卡!!!
2018年7月28日 下午10:06 10楼
加点人气
2017年12月24日 上午7:02 11楼
非常棒