egrep命令作用是在文件内查找指定的字符串。

egrep执行效果与grep -E相似,使用的语法及参数可参照grep指令,与grep的不同点在于解读字符串的方法。

egrep命令为 grep 的扩充版本, 改良了许多传统 grep 不能或不便的操作. 比方说:
grep之下不支持 ? 与 + 这两种modifier, 但egrep可以。
grep不支持 a|b 或 (abc|xyz) 这类”或一”比对, 但egrep可以。
grep在处理 {n,m} 时, 需用 \{ 与 \} 处理, 但egrep则不需要。

语法格式:egrep [参数] [文件]

常用参数:

-i搜索时,忽略大小写
-c只输出匹配行的数量
-l只列出符合匹配的文件名,不列出具体的匹配行
-n列出所有的匹配行,显示行号
-h查询多文件时不显示文件名
-s不显示不存在、没有匹配文本的错误信息
-v显示不包含匹配文本的所有行
-w匹配整词
-x匹配整行
-r递归搜索
-q禁止输出任何结果,已退出状态表示搜索是否成功
-b打印匹配行距文件头部的偏移量,以字节为单位
-o与-b结合使用,打印匹配的词据文件头部的偏移量,以字节为单位

参考实例

在文件里筛选包含“a”一个或一个以上的字符:

[root@linuxcool ~]# egrep 'a+'  linuxcool.txt

筛选字符串包含abc或123的字符:

[root@linuxcool ~]# egrep 'abc|123' linuxcool.txt

筛选包含abc整体的字符:

[root@linuxcool ~]# egrep '(abc)'  linuxcool.txt

筛选包含abc整体的一个或多个字符:

[root@linuxcool ~]# egrep '(abc)+'  linuxcool.txt
Author

这篇优质的内容由TA贡献而来

姜传广

网络工程师,linux爱好者