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
[[email protected] ]# aias grep=‘grep -E --color‘ # -E 相当于egrep
2、 -c 统计匹配到的部分的总行数
[[email protected] ]# grep -c ‘root‘ /etc/passwd 2
3、-n 出匹配到的部分及行号
[[email protected] ]# grep -n ‘root‘ /etc/passwd 1:root:x:0:0:root:/root:/bin/bash 11:operator:x:11:0:operator:/root:/sbin/nologin/
4、-o 仅输出文件中匹配到的部分
[[email protected] ]# grep -o ‘root‘ /etc/passwd root root root root
5、-v 反转查找
[[email protected] ]# 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行
[[email protected] ]# 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 对目标下的文件进行遍历
[[email protected] ]# 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:# as root). 匹配到二进制文件 /etc/alternatives/libip4tc0.x86_64
8、-e 指定多个匹配样式
echo this is a text line | 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 -0 rm #执行后会删除file1和file3,grep输出用-Z选项来指定以0值字节作为终结符文件名(\0),xargs -0 读取输入并用0值字节终结符分隔文件名,然后删除匹配文件,-Z通常和-l结合使用
10、-b 打印匹配字符所位于的字符或字节位置
echo gun is not unix | grep -b -o "not" 7:not #从该 行的第一个字符开始计算,起始值为0。选项 -b -o 一般总是配合使用。
11、在多个文件中查找
[[email protected] ]# grep ‘root‘ passwd passwd1 passwd:root:x:0:0:root:/root:/bin/bash passwd:operator:x:11:0:operator:/root:/sbin/nologin passwd1:rootrootrootasdlfjaksjdklfajksdfjaskdf
12、过滤出所有包含数字的行
[[email protected] ]# grep ‘[0-9]‘ /etc/passwd
13、过滤出以非数字开头的行
[[email protected] ]# grep ‘^[^0-9]‘ 1.txt
14、去除所有以#开头/结尾的行
[[email protected] ]# grep -v ‘^#‘ 1.txt [[email protected] ]# grep -v ‘#$‘ passwd
15、去除所有空行和
[[email protected] ]# grep -v ‘^$‘ 1.txt
15、过滤出以英文字母开头的行
[[email protected] ]# grep ‘^[a-zA-Z]‘ 1.txt
16、指定过滤字符次数
[[email protected] ]# grep ‘o\{2\}‘ 1.txt #没用egrep所以需要脱义
17、扩展应用
[[email protected] ]# egrep ‘roo|body‘ 1.txt
#匹配roo或者匹配body
[[email protected] ]# egrep ‘r(oo)|(at)o‘ 1.txt
#用括号表示一个整体
[[email protected] ]# egrep ‘(oo)+‘ 1.txt #表示1个或者多个 ‘oo‘
. 表示任意一个字符(包括特殊字符)
* 表示零个或多个*前面的字符
.* 表示任意个任意字符(包含空行)
+ 表示1个或多个+前面的字符
? 表示0个或1个?前面的字符
其中,+ ? grep不支持,egrep或者grep -E才支持。
时间: 2024-11-25 04:19:25