grep的作用就是搜索,与find不同的是:
find用于搜索目录,文件名
grep最根本上是用于检索文件内容,字符串等
grep [OPTIONS] PATTERN [FILE...] grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]
OPTIONS:(最常用的)
-a 以文本文件方式搜索
-c 计算找到的符合行的次数
-i 忽略大小写
-n 顺便输出行号
-v 反向选择,即找 没有搜索字符串的行
PATTERN:
(1) 要搜索的字符串
(2) 基本正则表达式
(3) 扩展正则表达式(需要 加 -E 参数)
[abc] 匹配字符串abc的中任何一个字符。
可以使用范围-
[a-z]:匹配所有小写英文字符
[A-Z]:匹配所有大写英文字符
[0-9]:匹配所有数字
[a-zA-Z]:匹配所有英文字符
bash中的.*与正则表达式有着不同的意义.
正则表达式:
. : 表示任意一个字符
* : 表示有0个或多个 某个字符, 例如 gx*可以匹配g的后面有一个或多个x字符: g, gx, gxx, gxxxx等,
^ex :匹配ex出现在行首
tion$:匹配tion出现在行尾
{n} | n是一个非负整数。匹配确定的n次。 |
---|---|
{n,} | n是一个非负整数。至少匹配n次。 |
{n,m} | m和n均为非负整数,其中n<=m。最少匹配n次且最多匹配m次。 |
注意,由于{ }在SHELL中有特殊意义,因此作为正则表达式用的时候要用\转义一下。
PATTERN1 | PATTERN2
实现匹配PATTERN1或者 PATTERN2
从中也可以看出‘|‘的优先级高于其他字符(当然小括号除外)
例如: 匹配字符串string或者char的字符串
grep -E 'string|char'
匹配以开头的字符串string或者char的字符串
grep -E '^string|^char'
和你小学学到的小括号的功能一样啦.
匹配以开头的字符串string或者char的字符串
grep -E '^(string|char)'
关于正则表达式的其他内容参见:
原文地址:http://blog.csdn.net/matrix_laboratory/article/details/40539477