grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来(匹配到的标红)。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。
它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到标准输出,不影响原文件内容。
grep可用于shell脚本,因为grep通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文件不存在,则返回2。我们利用这些返回值就可进行一些自动化的文本处理工作。
egrep = grep -E:扩展的正则表达式 (除了\< , \> , \b 使用其他正则都可以去掉\)
语法格式
grep [option] pattern file
常用option演示,更多option请查看手册
# cat > test.txt <<EOF
aaa
bbbbb
AAAaaa
BBBBASDABBDA
EOF
-A<显示行数>:除了显示符合范本样式的那一列之外,并显示该行之后的内容。
# grep -A2 b test.txt
-B<显示行数>:除了显示符合样式的那一行之外,并显示该行之前的内容。
# grep -B1 b test.txt
-C<显示行数>:除了显示符合样式的那一行之外,并显示该行之前后的内容。
# grep -C1 b test.txt
-c:统计匹配的行数
# grep -c aaa test.txt
-e :实现多个选项间的逻辑or 关系
# grep -e AAA -e bbb test.txt
-E:扩展的正则表达式
# grep -E "^A.*a$" test.txt
-f FILE:从FILE获取PATTERN匹配
# cat > pattern.txt <<EOF
aaa
EOF
# grep -f pattern.txt test.txt
-i --ignore-case :忽略字符大小写的差别。
# grep -i bbb test.txt
-n:显示匹配的行号
# grep -n b test.txt
-o:仅显示匹配到的字符串
# grep -o bbb test.txt
-q: 静默模式,不输出任何信息
# grep -q a test.txt
-s:不显示错误信息。
# grep -s aaa test.txt1
没有文件时不报错,-q依旧会报错
-v:显示不被pattern 匹配到的行,相当于[^] 反向匹配
# grep -v aaa test.txt
-w :匹配整个单词
# grep -w aaa test.txt