grep是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行显示出来。Unix 的 grep 家族包括 grep 、egrep 、 fgrep 。egrep 表示扩展的 grep ,相比 grep 支持更多的元字符。grep -E 相当于 egrep 。fgrep 是 fast grep ,不支持元字符,但是搜索速度更快。如果查找模式中包含空格,就必须用引号把它括起来。
语法:
grep [参数] 匹配的模式 [查询的文件…]
参数:
-h 不显示查询的文件名
-n 显示内容所在的行号
-r 递归查找
-l 只显示匹配模式的文件名,这会快些
-L 同l相反,显示没查到内容的文件名
-C 数字n 除了内容所在行,还额外多显示上边和下边各n行
-c 打印出含有模式的行的数目。count统计,统计匹配结果的行数,主要不是匹配结果的次数,是行数。
-i 查找字符时忽略大小写区别。这会有点慢
例如:
grep -rl A0651J *
递归查找当时目录下包含A0651J字符串的文件名,因为只需要返回文件名,所以查询速度很快。文件多时,可以这么先确认文件位置,再去查看。
grep -rn -C 6 A0651J ./*
递归查找当时目录下包含A0651J字符串的内容。这儿设置参数 -C 6 ,除了查找内容所在行,还会额外多显示所在行上边和下边各6行内容。
如果觉得查找显示的内容前边有文件名占用空间过多,不好看,可以加上h参数隐藏文件名。eg: grep -rnh -C 6 A0651J ./*
grep -c 'north' test.txt t2.sh
显示两个文件中分别包含north的行数
grep 的程序输入可以来自标准输入或管道,而不仅仅是文件。
如果输入来自管道,就会有另一条命令的输出通过管道变成 grep命令的输入,如果匹配到要查找的模式,grep 会把输出打印在屏幕上。
例如
ps -aux | grep tomcat8
ps命令的输出被送到 grep,然后所有包含tomcat8 的行都被打印在屏幕上。
ls | grep "^s"
显示当前目录下首字母为s的文件或目录
cat php.log | grep -E "成功|失败"
cat php.log | egrep "成功|失败"
grep -E "成功|失败" php.log
这三条语句是相同的,使用正则表达式的方式实现搜索包含多个字符串之一的行,这儿是或的关系,同时搜索包含"成功" 或 "失败"的行
cat /tmp/php.log | grep "成功" | grep "失败"
使用筛选的方式实现搜索同时包含多个字符串的行,这儿是与的关系,搜索同时包含"成功"和"失败"的行