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