grep命令
grep(global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。
grep语法格式:
grep [-options] 'word' filename
-c统计匹配到的部分的总行数 -n输出匹配到的部分及行号 -o仅输出文件中匹配到的部分 -v反转查找 -An关键字所在行及上n行 -Bn关键字所在行及下n行 -Cn关键字所在行及上下n行 -r对目标下的文件进行遍历 -E使用扩展正则表达式 -i忽略大小写 -q不显示任何信息,运行成功返回0,失败则返回非0值,一般用于条件测试 -d指定要查找的是目录而非文件,否则grep命令将回报信息并停止动作 -e指定字符串作为要查找的文件内容 -I列出文件内容符合指定的范本样式的文件名称 -L列出文件内容不符合指定的范本样式的文件名称 -Z指定以0值字节作为终结符文件名 -b在显示匹配内容的那一行之外,并显示该行之前的内容。
grep命令常见用法:
1、为了方便使用,首先定义alias
[root@test1]#aiasgrep='grep-E--color' #-E相当于egrep
2、 -c 统计匹配到的部分的总行数
[root@test1]#grep-c'root'/etc/passwd 2
3、-n 出匹配到的部分及行号
[root@test1]#grep-n'root'/etc/passwd 1:root:x:0:0:root:/root:/bin/bash 11:operator:x:11:0:operator:/root:/sbin/nologin/
[root@test1]#grep-o'root'/etc/passwd root root root root
5、-v 反转查找
[root@test1]#grep-v'root'/etc/passwd bin:x:1:1:bin:/bin:/sbin/nologin daemon:x:2:2:daemon:/sbin:/sbin/nologin adm:x:3:4:adm:/var/adm:/sbin/nologin lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
6、-An 关键字所在行及上n行 -Bn 关键字所在行及下n行 -Cn 关键字所在行及上下n行
[root@test1]#grep-C1-n'root'/etc/passwd 1:root:x:0:0:root:/root:/bin/bash 2-bin:x:1:1:bin:/bin:/sbin/nologin -- 10-uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin 11:operator:x:11:0:operator:/root:/sbin/nologin 12-games:x:12:100:games:/usr/games:/sbin/nologin
7、-r 对目标下的文件进行遍历
[root@test1]#grep-r'root'/etc/ /etc/passwd:root:x:0:0:root:/root:/bin/bash /etc/passwd:operator:x:11:0:operator:/root:/sbin/nologin /etc/yum/pluginconf.d/fastestmirror.conf:#asroot). 匹配到二进制文件/etc/alternatives/libip4tc0.x86_64
8、-e 指定多个匹配样式
echothisisatextline|grep-e"is"-e"line"-o is line
9、-IZ 使用0值字节后缀的grep与xargs
echo"aaa">file1 echo"bbb">file2 echo"aaa">file3 grep'aaa'file*-lZ|xargs-0rm #执行后会删除file1和file3,grep输出用-Z选项来指定以0值字节作为终结符文件名(\0),xargs-0读取输入并用0值字节终结符分隔文件名,然后删除匹配文件,-Z通常和-l结合使用
10、-b 打印匹配字符所位于的字符或字节位置
echogunisnotunix|grep-b-o"not" 7:not #从该行的第一个字符开始计算,起始值为0。选项-b-o一般总是配合使用。
11、在多个文件中查找
[root@test1]#grep'root'passwdpasswd1 passwd:root:x:0:0:root:/root:/bin/bash passwd:operator:x:11:0:operator:/root:/sbin/nologin passwd1:rootrootrootasdlfjaksjdklfajksdfjaskdf
12、过滤出所有包含数字的行
[root@test1]#grep'[0-9]'/etc/passwd
13、过滤出以非数字开头的行
[root@test1]#grep'^[^0-9]'1.txt
14、去除所有以#开头/结尾的行
[root@test1]#grep-v'^#'1.txt [root@test1]#grep-v'#$'passwd
15、去除所有空行和
[root@test1]#grep-v'^$'1.txt
15、过滤出以英文字母开头的行
[root@test1]#grep'^[a-zA-Z]'1.txt
16、指定过滤字符次数
[root@test1]#grep'o\{2\}'1.txt #没用egrep所以需要脱义
17、扩展应用
[root@test1]#egrep'roo|body'1.txt
#匹配roo或者匹配body
[root@test1]#egrep'r(oo)|(at)o'1.txt
#用括号表示一个整体
[root@test1]#egrep'(oo)+'1.txt #表示1个或者多个'oo'
过滤一个目录下所有*.PHP文档中含有eval的行
[root@test1]#grep-r--include=“*.PHP"‘eval'/data/
. 表示任意一个字符(包括特殊字符)
* 表示零个或多个*前面的字符
.* 表示任意个任意字符(包含空行)
+ 表示1个或多个+前面的字符
? 表示0个或1个?前面的字符