grep (global search regular expression(RE)全面搜索正则表达式)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。grep家族包括grep、egrep、fgrep。egrep和fgrep的命令只跟grep有很小不同。egrep是grep的扩展,支持更多的re元字符, fgrep就是fixed grep或fast grep,它们把所有的字母都看作单词,也就是说,正则表达式中的元字符表示回其自身的字面意义,不再具有其他特殊含义,一般使用较少。linux使用GNU版本的grep。它功能更强,可以通过-G、-E、-F命令行选项来使用egrep和fgrep的功能。
grep基本语法格式
grep [-acinvABC] 'word' filename -a :以文本文件方式进行搜索 -c :打印符合要求的行数 -i :忽略大小写 -n :在输出符合要求的行的同时连同行号一起输出 -v :打印不符合要求的行 -A :后跟一个数字(有无空格都可以),例如 –A2则表示打印符合要求的行以及下面两行 -B :后跟一个数字,例如 –B2 则表示打印符合要求的行以及上面两行 -C :后跟一个数字,例如 –C2 则表示打印符合要求的行以及上下各两行 正则表达式中:. 表示任意一个字符, * 表示零个或多个前面的字符,^表示行的开始, $表示行的结尾,^$表示空行,[]表示匹配括号任意一个字符,[^字符] 表示除方括号内的字符之外的字符
过滤出带有某个关键词的行并输出行号
grep -n 'root' /etc/passwd 1:root:x:0:0:root:/root:/bin/bash 11:operator:x:11:0:operator:/root:/sbin/nologin
过滤出不带有某个关键词的行并输出行号
grep -nv 'nologin' /etc/passwd 1:root:x:0:0:root:/root:/bin/bash 6:sync:x:5:0:sync:/sbin:/bin/sync 7:shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown 8:halt:x:7:0:halt:/sbin:/sbin/halt
过滤出所有包含数字的行
grep '[0-9]' /etc/inittab # upstart works, see init(5), init(8), and initctl(8). # 0 - halt (Do NOT set initdefault to this) # 1 - Single user mode # 2 - Multiuser, without NFS (The same as 3, if you do not have networking) # 3 - Full multiuser mode # 4 - unused # 5 - X11 # 6 - reboot (Do NOT set initdefault to this) id:3:initdefault:
过滤出所有不包含数字的行
grep -v '[0-9]' /etc/inittab
过滤出不以#开头的行
grep -v '^#' /etc/inittab id:3:initdefault:
过滤出不以#开头的非空行
grep -v '^#' /etc/crontab |grep -v '^$' SHELL=/bin/bash PATH=/sbin:/bin:/usr/sbin:/usr/bin MAILTO=root HOME=/
过滤出不以字母开头的行
grep '^[^a-zA-Z]' test.txt
过滤出包含非字母的行
grep '[^a-zA-Z]' test.txt
过滤任意一个字符
grep 'r..o' /etc/passwd operator:x:11:0:operator:/root:/sbin/nologin gopher:x:13:30:gopher:/var/gopher:/sbin/nologin vcsa:x:69:69:virtual console memory owner:/dev:/sbin/nologin
过滤重复字符
grep 'ooo*' /etc/passwd root:x:0:0:root:/root:/bin/bash lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin mail:x:8:12:mail:/var/spool/mail:/sbin/nologin uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin operator:x:11:0:operator:/root:/sbin/nologin postfix:x:89:89::/var/spool/postfix:/sbin/nologin
匹配所有行
grep '.*' /etc/passwd |wc -l #.*表示零个或多个任意字符,空行也包含在内。
过滤指定字符出现的次数
grep 'o\{2\}' /etc/passwd root:x:0:0:root:/root:/bin/bash lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin mail:x:8:12:mail:/var/spool/mail:/sbin/nologin uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin operator:x:11:0:operator:/root:/sbin/nologin postfix:x:89:89::/var/spool/postfix:/sbin/nologin #{ }表示前面的字符要重复的次数。使用时两边需要加上转义字符 \。{n1,}表示至少n1次。{n1,n2}表示n1至n2次。
egrep筛选一个或一个以上前面的字符
egrep 'o+' test.txt
egrep筛选零个或一个前面的字符
egrep 'o?' test.txt
egrep筛选字符串1或字符串2
egrep 'aaa|ooo' test.txt
egrep中( )的应用
egrep 'r(oo|at)o' test.txt egrep '(oo)+' test.txt #用( )表示一个整体,例如(oo)+就表示1个 ‘oo’ 或者多个 ‘oo’
转载请注明:零五宝典 » grep / egrep 工作日常用法总结