这一节学习了通配符和正则表达式在grep里面使用。
首先看看Shell下的通配符。
最最常见的符号如下所示:
数字 [0-9]
字母 [a-z]
非字母[^a-z]
非数字[^0-9]
任意符号 *
转义符号 \
大写 [[:upper:]]
小写 [[:lower:]]
数字 [[:digit:]]
字母 [[:alpha:]]
数字+字母[[:alnum:]]
空格 [[:blank:]]
看看例子
例1
第一个列出了数字和字母开头的文件
第二个列出了数字和-开头的文件
第三个列出来了数字开头的文件
例2
如果直接查找vsftp* 没问题;但是如果在当前目录下创建了匹配这个格式的文件,那得到的结果就是当前目录的文件而不是软件包了,因为yum是shell 的子进程,这个* 通配符在shell就被解析了;可以加引号或者转移符号来避免误会
下面来看看正则表达式在grep里面的使用
grep之前已经学习过了,简单的表达形式是 【grep 选项 字符串 文件】
选项可以是-n 行号,-v 反向选择,-a 文本文件,-i 忽略大小写
通配符在grep一样可以使用,不过有的符号意思发生了改变。
例3
先看个基本的例子,反向搜索没有#的行,如果不加引号,他会被shell直接解析,而不是在grep中进行解析
^符号如果是在方括号里面,表示否定; 如果是单引号里面表示这个字符串是以^后面的字符开头的
对比如下所示
如果表示结尾的字符,可以用'$',如果直接输入‘^$',则表示空行
例4
空行
如何表示一个或者多个字符?我们可以用. (小圆点)来表示任意一个符号,表示这个位置就有个符号,随便是啥都行;* (星号) 可以表示有0个或者多个重复的符号,比如to* 可以表示的格式是tXXXXXXXX,toXXXXX,tooXXXXXXX ...都是可以的
例5 比如 to* 和 t.m的区别
除了 小圆点和星号,我们还可以使用?表示0或1次; +表示1次以上, {m,n}表示表达式出现至少m次,最多n次;这需要使用扩展正则表达式-P或者-E,否则直接运行无效
例 6 直接运行没有结果,-P用perl的方式来解析,就可以了 {3}表示 o 出现3次,{2,4}表示出现了2次到4次
to.?m 里面 . 表示任意一个字符,?表示这个任意字符出现了0次或者1次,因此满足 tom,toXm 的字符串都是可以的
类似的 to.+m里面 .表示任意字符,+表示这个字符出现了1次或者多次,那么匹配的字符串是toXm,toXXm,toXXXm,换句话说满足to开头,m结尾的字符串都是可以的
最后做个练习,如何只输出ifconfig里面ip的结果,不准用awk
这个能够匹配的写法太多了,豆子自己写了个比较复杂的
下面是老师的写法