这一节学习了通配符和正则表达式在grep里面使用。


首先看看Shell下的通配符。 


最最常见的符号如下所示:


数字 [0-9]

字母 [a-z]

非字母[^a-z]

非数字[^0-9]

任意符号 *

转义符号 \

大写 [[:upper:]] 

小写 [[:lower:]]

数字 [[:digit:]]

字母 [[:alpha:]]

数字+字母[[:alnum:]]

空格 [[:blank:]]



看看例子


例1


第一个列出了数字和字母开头的文件

第二个列出了数字和-开头的文件

第三个列出来了数字开头的文件


RHCE 学习笔记(17) 通配符和正则表达式_第1张图片


例2


如果直接查找vsftp* 没问题;但是如果在当前目录下创建了匹配这个格式的文件,那得到的结果就是当前目录的文件而不是软件包了,因为yum是shell 的子进程,这个* 通配符在shell就被解析了;可以加引号或者转移符号来避免误会


wKiom1SvV3KizXxcAACo4jh0vP8885.jpg

wKioL1SvWDejnlnyAACl4C2a8QI896.jpg


下面来看看正则表达式在grep里面的使用


grep之前已经学习过了,简单的表达形式是 【grep 选项 字符串 文件】


选项可以是-n 行号,-v 反向选择,-a 文本文件,-i 忽略大小写


通配符在grep一样可以使用,不过有的符号意思发生了改变。


例3


先看个基本的例子,反向搜索没有#的行,如果不加引号,他会被shell直接解析,而不是在grep中进行解析


RHCE 学习笔记(17) 通配符和正则表达式_第2张图片


^符号如果是在方括号里面,表示否定; 如果是单引号里面表示这个字符串是以^后面的字符开头的

对比如下所示


RHCE 学习笔记(17) 通配符和正则表达式_第3张图片


如果表示结尾的字符,可以用'$', 如果直接输入‘^$', 则表示空行


例4


wKiom1SvV3jxkefSAABmpk7zatY177.jpg


空行

wKioL1SvWDzBc-UWAAA9GexwFtI209.jpg


如何表示一个或者多个字符?我们可以用. (小圆点)来表示任意一个符号,表示这个位置就有个符号,随便是啥都行;* (星号) 可以表示有0个或者多个重复的符号,比如to* 可以表示的格式是tXXXXXXXX,toXXXXX,tooXXXXXXX ...都是可以的


例5 比如 to* 和 t.m的区别


RHCE 学习笔记(17) 通配符和正则表达式_第4张图片



除了 小圆点和星号,我们还可以使用?表示0或1次; +表示1次以上, {m,n}表示表达式出现至少m次,最多n次;这需要使用扩展正则表达式-P或者-E,否则直接运行无效


例 6  直接运行没有结果,-P用perl的方式来解析,就可以了 {3}表示 o 出现3次,{2,4}表示出现了2次到4次


RHCE 学习笔记(17) 通配符和正则表达式_第5张图片


to.?m 里面 . 表示任意一个字符,?表示这个任意字符出现了0次或者1次,因此满足 tom, toXm 的字符串都是可以的

wKioL1SvYqfzrjgIAAA7pikB6KQ406.jpg


类似的 to.+m里面 .表示任意字符,+表示这个字符出现了1次或者多次,那么匹配的字符串是toXm,toXXm,toXXXm,换句话说满足to开头,m结尾的字符串都是可以的

wKiom1SvYpGR4P6nAAA-KmpLZAk477.jpg


最后做个练习,如何只输出ifconfig里面ip的结果,不准用awk


这个能够匹配的写法太多了,豆子自己写了个比较复杂的

wKiom1SvbrXxxC-wAACToHqPorc494.jpg

下面是老师的写法


wKioL1SvcQuxnNQnAAB8bcNhuSI235.jpg