首页 > Linux命令大全 > grep 搜索目录中的文件

grep 搜索目录中的文件

2017年2月4日

grep 搜索目录中的文件

http://blog.csdn.net/tsxw24/article/details/7828357

1.在某目录下的所有文件中搜索确定的关键词
grep -Fnr class ./
以上命令的意思是:在当前目录下的所有文件中搜索“class”,并显示文件名、行号和匹配所在行内容

2.在某目录下的所有文件中,按使用正则搜索
grep -Pnr “\d{3}” ./

-P 是 Perl 正则表达式,经过测试,发现此模式支持的正则最完整,支持正则的完整度由大到小为: -P > -E > -G
建议正则搜索时就直接使用-P模式,以避免去记忆-E和-G模式不支持的正则列表
3.只搜索某一类文件
grep -Pnr “\d{3}” `find -name “*.txt”`

4.只搜索某几类文件,如下,只搜索txt和php文件

grep -Pnr “\d{3}” `find |grep -P “.(txt|php)$”`

5.排除含某关键词的子目录不搜索。如下,含“weiba”关键词的子目录不搜索

grep -Pnr “\d{3}” `ls |grep -Fv weiba`
-v排除匹配项
6.更强功能的子目录筛选
grep -Pnr “\d{3}” `ls |grep -Pv ‘^(weiba|huati)$’`

grep -Pnr “\d{3}” `ls |grep -P ‘^(weiba|huati)$’`

附:greg 使用帮助
用法: grep [选项]… PATTERN [FILE]…

在每个 FILE 或是标准输入中查找 PATTERN。
默认的 PATTERN 是一个基本正则表达式(缩写为 BRE)。
例如: grep -i ‘hello world’ menu.h main.c
正则表达式选择与解释:
-E, –extended-regexp PATTERN 是一个可扩展的正则表达式(缩写为 ERE)
-F, –fixed-strings PATTERN 是一组由断行符分隔的定长字符串。
-G, –basic-regexp PATTERN 是一个基本正则表达式(缩写为 BRE)
-P, –perl-regexp PATTERN 是一个 Perl 正则表达式
-e, –regexp=PATTERN 用 PATTERN 来进行匹配操作
-f, –file=FILE 从 FILE 中取得 PATTERN
-i, –ignore-case 忽略大小写
-w, –word-regexp 强制 PATTERN 仅完全匹配字词
-x, –line-regexp 强制 PATTERN 仅完全匹配一行
-z, –null-data 一个 0 字节的数据行,但不是空行
杂项:
-s, –no-messages 不显示错误信息
-v, –invert-match 选中不匹配的行
-V, –version 显示版本信息并退出
–help 显示此帮助并退出
–mmap 忽略向后兼容性
输出控制:
-m, –max-count=NUM NUM 次匹配后停止
-b, –byte-offset 输出行的同时打印字节偏移
-n, –line-number 输出行的同时打印行号
–line-buffered 每行输出清空
-H, –with-filename 为每一匹配项打印文件名
-h, –no-filename 输出时不显示文件名前缀
–label=LABEL 标准输入将LABEL 打印为文件名
-o, –only-matching 只显示一行中匹配PATTERN 的部分
-q, –quiet, –silent 不显示所有输出
–binary-files=TYPE 假定二进制文件的TYPE 类型;
TYPE 可以是`binary’, `text’, 或`without-match’
-a, –text 等同于 –binary-files=text
-I 等同于 –binary-files=without-match
-d, –directories=ACTION 操作目录的方式;
ACTION 可以是`read’, `recurse’,或`skip’
-D, –devices=ACTION 操作设备、先入先出队列、套接字的方式;
ACTION 可以是`read’或`skip’
-R, -r, –recursive 等同于 –directories=recurse
–include=FILE_PATTERN 只查找匹配FILE_PATTERN 的文件
–exclude=FILE_PATTERN 跳过匹配FILE_PATTERN 的文件和目录
–exclude-from=FILE 跳过所有除FILE 以外的文件
–exclude-dir=PATTERN 跳过所有匹配PATTERN 的目录。
-L, –files-without-match 只打印不匹配FILEs 的文件名
-l, –files-with-matches 只打印匹配FILES 的文件名
-c, –count 只打印每个FILE 中的匹配行数目
-T, –initial-tab 行首tabs 分隔(如有必要)
-Z, –null 在FILE 文件最后打印空字符
文件控制:
-B, –before-context=NUM 打印以文本起始的NUM 行
-A, –after-context=NUM 打印以文本结尾的NUM 行
-C, –context=NUM 打印输出文本NUM 行
-NUM 等同于 –context=NUM
–color[=WHEN],
–colour[=WHEN] 使用标志高亮匹配字串;
WHEN 可以是`always’, `never’或`auto’
-U, –binary 不要清除行尾的CR 字符(MSDOS 模式)
-u, –unix-byte-offsets 当CR 字符不存在,报告字节偏移(MSDOS 模式)
‘egrep’即‘grep -E’。‘fgrep’即‘grep -F’。
直接使用‘egrep’或是‘fgrep’均已不可行了。
不带 FILE 参数,或是 FILE 为 -,将读取标准输入。如果少于两个 FILE 参数
就要默认使用 -h 参数。如果选中任意一行,那退出状态为 0,否则为 1;
如果有错误产生,且未指定 -q 参数,那退出状态为 2。

分类: Linux命令大全 标签:
本文的评论功能被关闭了.