分类
grep
grep -E 拓展正则
egrep
拓展正则
\w 所有的字母和数字
[z-zA-Z0-9]
\W 所有的非字符,即出字母和数字以外的字符
\b 词边界
\<love\> === \blove\b
fgrep
就不支持正则,没有任何特性
返回值
0 找到了
1 没找到
2 找的地方不对
参数
grep -q
#静默,不显示执行结果,但可以用echo $?来查看执行情况
grep -v
#取反,
grep -R
#可以查目录下的文件内容
grep -o
#只找到这个关键字
grep -B2
#前两行,显示周围文件
grep -A2
#后两行,显示周围文件
grep -C2
#上下两行,显示周围文件
egrep -|
#只显示文件名
egrep -n
#带行号
示例
egrep 'NW' datafile.txt
#在datafile.txt搜索NW
egrep 'NW' d*.txt
#在以d什么作为文件名的文件中找NW
egrep '^n' datafile.txt
#以n作为行首
egrep '4$' datafile.txt
#以4作为行尾
egrep TB Savage datafile.txt
#在两个文件中找TB
egrep 'TB Savage' datafile.txt
#找TB Savage
egrep '5\..' datafile.txt
#找5.什么
egrep '\.5' datafile.txt
#找.5
egrep '^[we]' datafile.txt
#以w或e开头
egrep '[^0-9]' datafile.txt
#非数字
egrep '[A-Z][A-Z] [A-Z]' datafile.txt
egrep 'ss*' datafile.txt
#一个s,后面可能0到多个s
egrep '[a-z]{9}' datafile.txt
#找9个小写字母
egrep '\<north' datafile.txt
#以north开头的词
egrep '\<north\>' datafile.txt
#找north单词
egrep '\<[a-r].*n\>' datdfile.txt
#找a-r开头,结尾是n的单词
egrep '^n\w*\W' datafile.txt
#以n行首,0到多个字母与数字,一个非字符
egrep '\bnorth\b' datafile.txt
egrep 'NW|EA' datafile.txt
#找NW或EA
egrep '3+' datafile.txt
#3出现1到多次
egrep '2\.?[0-9]' datafile.txt
#2点几或20几,?0到1次
egrep '(no)+' datafile.txt
#1到多个no
egrep 'S(H|u)' datafile
#SH或Su
egrep 'SH|u' datafile
#SH或U