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 |