使用场景
主要用于查找,过滤文本数据;该数据可以来自文件,也可以来自管道流等等。
grep除了原有的实现,后来还出现了以下扩展实现
-
egrep:支持扩展的正则匹配(+, ? ,|, \w(匹配大小写字母和数字,相当于[A-Za-z0-9]),\W (所有非字母数字 = [^A-Za-z0-9]),\b 边界词 \bxxx\b相当于 \<xxx\>)
-
fgrep 以普通字符形式匹配,相当于没有正则规则。
grep -E ≈ egrep
grep \ ≈ fgrep
基本使用
为了支持扩展正则,通常会加 -E
返回值
grep 执行后饭返回值
- 匹配上返回 0
- 未匹配上返回 1
- 没有数据可匹配 返回 2
参数
-q :不显示匹配结果,但依然有返回值,可以通过 $?获取
-v :从结果中过滤掉 -v的后的数据
-R :匹配指定目录下的所有文件
-o :只显示匹配的关键字
-B:显示上面多少行 -B10向上显示10行
-A :显示下面多少行 -A10向下显示10行
-C : 显示上下多少行 -C10上下都显示10行
-l :只显示文件名
-n :带上行号显示
-i :忽略大小写
-m :展示几条。有点limit的感觉
egrep 查找内容 查找的文件1 [查找的文件2 …]
使用示例
基本语法为:grep/egrep/fgrep ‘条件字符串’
有文本文件 test_reg.txt 如下
a
ab
ac
abc
abbc
abbbc
abbbcc
- 查找包含a的行
grep 'a' test_reg.txt
a
ab
ac
abc
abbc
abbbc
abbbcc
- 查询以a结尾的行
grep 'a$' test_reg.txt
a
其他参考正则使用即可