Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。
grep的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到标准输出,不影响原文件内容。
grep可用于shell脚本,因为grep通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文件不存在,则返回2。我们利用这些返回值就可进行一些自动化的文本处理工作。
1.命令格式
grep [option] pattern file
2.命令参数
-a, --text:
Process a binary file as if it were text; this is equivalent to the --binary-files=text option.
-c --count:
计算符合样式的列数
-d:
当指定要查找的是目录而非文件时,必须使用这项参数,否则grep指令将回报信息并停止动作。
-f<规则文件> --file=<规则文件>:
指定规则文件,其内容含有一个或多个规则样式,让grep查找符合规则条件的文件内容,格式为每行一个规则样式。
-i --ignore-case:
忽略字符大小写的差别。
-n:
在显示符合样式的那一行之前,标示出该行的列数编号
--color[=WHEN], --colour[=WHEN]:
以特定颜色高亮显示匹配关键字
-A NUM, --after-context=NUM:
Print NUM lines of trailing context after matching lines。
-B NUM, --before-context=NUM:
Print NUM lines of leading context before matching lines。
-C NUM, -NUM, --context=NUM:
Print NUM lines of output context。
-v --revert-match:
显示不包含匹配文本的所有行。
-G, --basic-regexp
-E, --extended-regexp
-P, --perl-regexp
3.grep 与正则表达式
grep 在查找字符串时,可以采用 Basic 和 Extended, perl 三种规范,也可以不用正则表达式。
**正则表达式分类:**
1、基本的正则表达式(Basic Regular Expression 又叫 Basic RegEx 简称 BREs)
2、扩展的正则表达式(Extended Regular Expression 又叫 Extended RegEx 简称 EREs)
3、Perl 的正则表达式(Perl Regular Expression 又叫 Perl RegEx 简称 PREs)
其实我们在大多数高级编程语言中所使用的正则表达式都源自Perl。实际上,正则表达式从Perl衍生出一个显赫的流派,叫做PCRE(Perl Compatible Regular Expression)。其他高级语言大多基于此修改或者扩展。而 Unix/Linux 下的工具大多采用POSIX规范,同时,POSIX规范又可分为两种流派,即 BREs 和 EREs。
TODO 常用正则表达式
4.使用实例
#查找指定进程, 去掉grep本身进程
[root@localhost ~]# ps -ef|grep svn | grep -v grep
root 4943 1 0 Dec05 ? 00:00:00 svnserve -d -r /opt/svndata/grape/
#从文件中(test2.txt)读取关键词进行搜索在test.txt中
[root@localhost test]# cat test.txt
hnlinux
peida.cnblogs.com
ubuntu
ubuntu linux
redhat
Redhat
linuxmint
[root@localhost test]# cat test2.txt
linux
Redhat
[root@localhost test]# cat test.txt | grep -nf test2.txt
1:hnlinux
4:ubuntu linux
6:Redhat
7:linuxmint
[root@localhost test]#
参考链接:
1. 每天一个Linux 命令: grep
2.Linux下grep 与正则表达式
3.man grep