Linux grep命令使用详解

1 引言 Grep (global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。Grep 家族包括Grep、 eGrep 和fGrep。eGrep 和fGrep 的命令只跟Grep 有很小不同。eGrep 是Grep 的扩展,支持更多的re 元字符, fGrep 就是 fixed Grep 或fast Grep,它们把所有的字母都看作单词,也就是说,正则表达式中的元字符表示回其自身的字面意义,不再特殊。linux 使用GNU 版本的Grep。它功能更强,可以通过-G、-E、-F 命令行选项来使用eGrep 和fGrep 的功能。Grep 的工作方式是这样的,它在一个或多个文 中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到屏幕,不影响原文件内容。Grep 可用于shell 脚本,因为Grep 通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文 不存在,则返回2 。我们利用这些返回值就可进行一些自动化的文本处理工作。2 Grep 详解

语  法:grep [-abcEFGhHilLnqrsvVwxy][-A<显示列数>][-B<显示列数>][-C<显示列数>][-d<进行动作>][-e<范本样式>][-f<范本文件>][–help][范本样式][文件或目录…]

补充说明:grep指令用于查找内容包含指定的范本样式的文件,如果发现某文件的内容符合所指定的范本样式,预设grep指令会把含有范本样式的那一列显示出来。若不指定任何文件名称,或是所给予的文件名为“-”,,则grep指令会从标准输入设备读取数据。

参  数:

-a或–text 不要忽略二进制的数据。-A<显示列数>或–after-context=<显示列数> 除了显示符合范本样式的那一列之外,并显示该列之后的内容。-b或–byte-offset 在显示符合范本样式的那一列之前,标示出该列第一个字符的位编号。-B<显示列数>或–before-context=<显示列数> 除了显示符合范本样式的那一列之外,并显示该列之前的内容。-c或–count 计算符合范本样式的列数。-C<显示列数>或–context=<显示列数>或-<显示列数> 除了显示符合范本样式的那一列之外,并显示该列之前后的内容。-d<进行动作>或–directories=<进行动作> 当指定要查找的是目录而非文件时,必须使用这项参数,否则grep指令将回报信息并停止动作。-e<范本样式>或–regexp=<范本样式> 指定字符串做为查找文件内容的范本样式。-E或–extended-regexp 将范本样式为延伸的普通表示法来使用。-f<范本文件>或–file=<范本文件> 指定范本文件,其内容含有一个或多个范本样式,让grep查找符合范本条件的文件内容,格式为每列一个范本样式。-F或–fixed-regexp 将范本样式视为固定字符串的列表。-G或–basic-regexp 将范本样式视为普通的表示法来使用。-h或–no-filename 在显示符合范本样式的那一列之前,不标示该列所属的文件名称。-H或–with-filename 在显示符合范本样式的那一列之前,表示该列所属的文件名称。-i或–ignore-case 忽略字符大小写的差别。-l或–file-with-matches 列出文件内容符合指定的范本样式的文件名称。-L或–files-without-match 列出文件内容不符合指定的范本样式的文件名称。-n或–line-number 在显示符合范本样式的那一列之前,标示出该列的列数编号。-q或–quiet或–silent 不显示任何信息。-r或–recursive 此参数的效果和指定“-d recurse”参数相同。-s或–no-messages 不显示错误信息。-v或–revert-match 反转查找。-V或–version 显示版本信息。-w或–word-regexp 只显示全字符合的列。-x或–line-regexp 只显示全列符合的列。-y 此参数的效果和指定“-i”参数相同。–help 在线帮助。

做自己的决定。然后准备好承担后果。

Linux grep命令使用详解

相关文章:

你感兴趣的文章:

标签云: