grep
grep(globalsearchregularexpression(RE)andprintouttheline,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。Unix的grep家族包括grep、egrep和fgrep。egrep和fgrep的命令只跟grep有很小不同。egrep是grep的扩展,支持更多的re元字符,fgrep就是fixedgrep或fastgrep,它们把所有的字母都看作单词,也就是说,正则表达式中的元字符表示回其自身的字面意义,不再特殊。Linux使用GNU版本的grep。它功能更强,可以通过-G、-E、-F命令行选项来使用egrep和fgrep的功能。
grep的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到屏幕,不影响原文件内容。
grep可用于shell脚本,因为grep通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文件不存在,则返回2。我们利用这些返回值就可进行一些自动化的文本处理工作。
grep--help
匹配模式选择:
-E,--extended-regexp扩展正则表达式egrep
-F,--fixed-strings一个换行符分隔的字符串的集合fgrep
-G,--basic-regexp基本正则
-P,--perl-regexp调用的perl正则
-e,--regexp=PATTERN后面根正则模式,默认无
-f,--file=FILE从文件中获得匹配模式
-i,--ignore-case不区分大小写
-w,--word-regexp匹配整个单词
-x,--line-regexp匹配整行
-z,--null-data一个0字节的数据行,但不是空行
杂项:
-s,--no-messages不显示错误信息
-v,--invert-match显示不匹配的行
-V,--version显示版本号
--help显示帮助信息
--mmapusememory-mappedinputifpossible
输入控制:
-m,--max-count=NUM匹配的最大数
-b,--byte-offset打印匹配行前面打印该行所在的块号码。
-n,--line-number显示的加上匹配所在的行号
--line-buffered刷新输出每一行
-H,--with-filename当搜索多个文件时,显示匹配文件名前缀
-h,--no-filename当搜索多个文件时,不显示匹配文件名前缀
--label=LABELprintLABELasfilenameforstandardinput
-o,--only-matching只显示一行中匹配PATTERN的部分
-q,--quiet,--silent不显示任何东西
--binary-files=TYPE假定二进制文件的TYPE类型;
TYPE可以是`binary',`text',或`without-match'
-a,--text匹配二进制的东西
-I不匹配二进制的东西
-d,--directories=ACTION目录操作,读取,递归,跳过
-D,--devices=ACTION设置对设备,FIFO,管道的操作,读取,跳过
-R,-r,--recursive递归调用
--include=PATTERN只查找匹配FILE_PATTERN的文件
--exclude=PATTERN跳过匹配FILE_PATTERN的文件和目录
--exclude-from=FILE跳过所有除FILE以外的文件
-L,--files-without-match匹配多个文件时,显示不匹配的文件名
-l,--files-with-matches匹配多个文件时,显示匹配的文件名
-c,--count显示匹配了多少次
-Z,--null在FILE文件最后打印空字符
文件控制:
-B,--before-context=NUM打印匹配本身以及前面的几个行由NUM控制
-A,--after-context=NUM打印匹配本身以及随后的几个行由NUM控制
-C,--context=NUM打印匹配本身以及随后,前面的几个行由NUM控制
-NUM根-C的用法一样的
--color[=WHEN],
--colour[=WHEN]使用标志高亮匹配字串;
-U,--binary使用标志高亮匹配字串;
-u,--unix-byte-offsets当CR字符不存在,报告字节偏移(MSDOS模式)
例:
测试文件
复制代码