grep的使用详解
GREP是GlobalRegularExpressionPrint的缩写
对于标准输入的每一行,grep执行以下的操作:
(1)把下一输入行复制到模式空间中.模式空间是只可保存一个文本行的缓冲区.
(2)对模式空间应用正则表达式.
(3)如果有匹配存在,该行从模式空间中被复制到标准输出.
注意grep处理下列情况的方式:
1.grep是一个搜索程序,它只能搜索匹配一个正则表达式的一行的存在性.
2.grep可以对一行采取唯一的动作是把它发送到标准输出.如果该行不匹配正则表达式,则其不被打印.
3.行的选择只基于正则表达式.行编号或其他准则不能用于选择行.
4.grep是一个过滤器.它可用在管道的左边或右边.
5.grep不能用于增加,删除或修改行.
6.grep不能用于只打印行的一部分.
7.grep不能只读取文件的一部分.
8.grep不能基于前面的内容或下一行来选择一行.只有一个缓冲区,它只保存当前行.
GREP族包括:grep,fgrep,egrep
fgrep:只支持字符串模式,不支持正则表达式.
grep:只支持数量有限的正则表达式.
egrep:支持大多数的正则表达式,但不是全部.
其中egrep就等同于grep-E,fgrep等同于grep-F
grep常用的选项:
-c只打印匹配模式的行编号记数
-i在匹配文本时忽略大小写
-n在每行前显示其行编号
-v逆向输出.打印不匹配模式的行
grep:
一般格式:grep[options]基本正则表达式[filename]
注意:基本正则表达式可以为字符串,如果是字符串的时候请加上“”号,否则容易出错
例子:
1.sh #!/bin/bash echo $0 | awk -F/ '{print $NF}' echo $1 | awk -F/ '{print $NF}' cp 1.sh 2.sh
1、查询多个文件:
[root@localhost ~]# grep 'echo' *.sh 1.sh:echo $0 | awk -F/ '{print $NF}' 1.sh:echo $1 | awk -F/ '{print $NF}' 2.sh:echo $0 | awk -F/ '{print $NF}' 2.sh:echo $1 | awk -F/ '{print $NF}'
2、行匹配
计算本目录下sh文件中包含echo字符的个数
[root@localhost ~]# grep -c "echo" *.sh 1.sh:2 2.sh:2
在每行前显示其行号
[root@localhost ~]# grep -n "echo" *.sh 1.sh:2:echo $0 | awk -F/ '{print $NF}' 1.sh:3:echo $1 | awk -F/ '{print $NF}' 2.sh:2:echo $0 | awk -F/ '{print $NF}' 2.sh:3:echo $1 | awk -F/ '{print $NF}'
逆向输出.打印不匹配模式的行
[root@localhost ~]# grep -v "echo" *.sh 1.sh:#!/bin/bash 2.sh:#!/bin/bash
在匹配文本时忽略大小写
[root@localhost ~]# grep -i "ECHO" *.sh 1.sh:echo $0 | awk -F/ '{print $NF}' 1.sh:echo $1 | awk -F/ '{print $NF}' 2.sh:echo $0 | awk -F/ '{print $NF}' 2.sh:echo $1 | awk -F/ '{print $NF}'