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@linux265 ~]# egrep 'a+' linux265.txt
筛选字符串包含abc或123的字符: [root@linux265 ~]# egrep 'abc|123' linux265.txt
筛选包含abc整体的字符: [root@linux265 ~]# egrep '(abc)' linux265.txt
筛选包含abc整体的一个或多个字符: [root@linux265 ~]# egrep '(abc)+' linux265.txt