参考百度百科

 

1、简介

grep (缩写来自Globally search a Regular Expression and Print)是一种强大的文本搜索工具,它能使用特定模式匹配(包括正则表达式)搜索文本,并默认输出匹配行

 

2、语法

grep [OPTIONS] PATTERN [FILE…]

 

3、表达符集

字符

说明

示例

^

锚定行的开始

'^grep'匹配所有以grep开头的行

$

锚定行的结束

'grep$'匹配所有以grep结尾的行

.

匹配一个非换行符('\n')的字符

'gr.p'匹配gr后接一个任意字符,然后是p

*

匹配零个或多个先前字符

' *grep' (注意*前有空格)匹配所有零个或多个空格后紧跟grep的行,需要用egrep 或者grep带上 -E 选项。 .*一起用代表任意字符。

[]

匹配一个指定范围内的字符

'[Gg]rep'匹配Grep和grep

[^]

匹配一个不在指定范围内的字符

'[^A-FH-Z]rep'匹配不包含A-F和H-Z的一个字母开头,紧跟rep的行

\(..\)

标记匹配字符

'\(love\)',love被标记为1

\<

锚定单词的开始

'\<grep'匹配包含以grep开头的单词的行

\>

锚定单词的结束

'grep\>'匹配包含以grep结尾的单词的行

x\{m\}

重复字符x,m次

'o\{5\}'匹配包含5个o的行

x\{m,\}

重复字符x,至少m次

'o\{5,\}'匹配至少有5个o的行

x\{m,n\}

重复字符x,至少m次,不多于n次

'o\{5,10\}'匹配5--10个o的行

\w

匹配文字和数字字符,也就是[A-Za-z0-9]

'G\w*p'匹配以G后跟零个或多个文字或数字字符,然后是p

\W

\w的反置形式,匹配一个或多个非单词字符,如点号句号等

 

\b

单词锁定符

'\bgrep\b'只匹配grep

\+

匹配一个或多个先前的字符

'[a-z]\+able',匹配一个或多个小写字母后跟able的串,如loveable,enable,disable等

\?

匹配零个或一个先前的字符

'gr\?p'匹配gr后跟一个或没有字符,然后是p的行

a\|b\|c

匹配a或b或c

grep|sed匹配grep或sed

\(\)

分组符号

love\(ab\le\|rs\)ov\+匹配loveable或lovers,匹配一个或多个ov

 

4、参数

 

参数

说明

-?

同时显示匹配行上下的?行

-b

打印匹配行前面打印该行所在的块号码

-c

只打印匹配到的行数(统计行数),不显示匹配的内容

-f File

从文件中提取模板。空文件中包含0个模板,所以什么都不匹配

-h

当搜索多个文件时,不显示匹配文件名前缀

-i

忽略大小写差别

-o

只显示正则表达式匹配的

-q

取消显示,只返回退出状态。0则表示找到了匹配的行,1为未匹配到,2为发生错误

-n

在匹配的行前面打印行号

-s

不显示关于不存在或者无法读取文件的错误信息(少用,一般将标准错误输出到/dev/null)

-v

反检索,只显示不匹配的行

-R,-r

递归的读取目录下的所有文件,包括子目录

-V

显示软件版本信息

-A6

查找某些字符的内容,并下延伸6行

-B6

查找某些字符的内容,并上延伸6行

-C1

查找某些字符的内容,并上和向下各延伸1行,这几行后面的数字直接影响延伸数量,并以--符号分割搜索行的结果

 

5、实例

匹配除包含 [ 特殊字符外的进程

ps -ef | grep -v '\['