GREP
其实 grep 是一段话的缩写:Global search regular expression and print
out the line(全面搜索研究正则表达式并显示出来)
作用:grep 命令是一种强大的文本搜索工具,根据用户指定的“模
式”对目标文本进行匹配检查,打印匹配到的行。
模式(patten):由正则表达式或者字符及基本文本字符所编写的过
滤条件
那什么是正则表达式(REGEXP)呢,下面我们做一个简单的介绍:
正则表达式:由一类特殊字符及文本字符所编写的模式,其中有些字
符不表示字符的字面意思,而表示控制或通配的功能(是不是比较难
理解)
分文两类:1.基本正则表达式(BRE):grep
2.扩展正则表达式 (ERE): egrep
grep –E
grep -i ^root file ###以root开头,i(ignore-case):忽略大小写
grep -i root$ file ###以root结尾
grep root -r /mnt/ ###显示/mnt/下文件中有root的行
grep -n root file ###显示行号
grep -A 1 root file ###显示file中root的后一行,A(after)
grep -B 1 root file ###显示file中root的前一行,B(before)
grep -E “root|lee” file ###过滤root以及lee (也可以用egrep)E(extended):扩展正则
grep [abc] file ###匹配里面任意一个字符
grep [^abc] file ###匹配不包含^后面的一个字符的内容(非a,b,c)
*)
egrep -n ‘a?c’ file ###n(number):显示行号?:重复0个或一个字符
egrep ‘a+c’ file ###+:重复前面一个或一个以上的前面字符
egrep a{n,m} file ###重复前一个字符n-m次
grep a{n,} file ###重复前一个字符至少n次(n-无穷)未加-E及扩展正则则要加\转义,sed -r也不用转义
egrep a{n} file ###重复前面一个字符n次
egrep a{,m} file ###重复前面最多m次
grep “n.m” file ###代表一个字符
grep “n*m” file ###重复0个或多个前面的字符
grep “\