用法:grep [选项] “模式” [文件]
/grep/egrep/fgrep
常用选项:
-E:开启扩展(extend)的正则表达式
-i:忽略大小写
#grep –I “root” /etc/passwd
root❌0:0:root:/root:/bin/bash
operator❌11:0:operator:/root:/sbin/nologin
dockerroot❌995:992:Docker User:/var/lib/docker:/sbin/nologin
-v:反过来,只打印没有匹配的,匹配的不打印
#ps -ef |grep gas-boot-1.0.0.jar|grep -v grep
-n:显示行号
#grep –n “root” /etc/passwd
1:root❌0:0:root:/root:/bin/bash
10:operator❌11:0:operator:/root:/sbin/nologin
-w:被匹配的文本只能是单词,而不是单词的一部分,比如like\liker,使用-w选项来避免匹配liker.
-c:显示多少行被匹配到了,而不显示匹配到的内容,使用-vc显示多少行没有被匹配到
-o: 只显示被模式匹配到的字符串
#grep –o “root” /etc/passwd
root
root
root
root
–color:将匹配到的内容高亮显示
-A n 显示匹配到的字符串所在的行及其后n行,A=after
#grep -A 2 “core id” /proc/cpuinfo
core id : 0
cpu cores : 1
apicid : 0
-B n 显示匹配到的字符串所在的行及其前n行,B=before
grep -B 2 “core id” /proc/cpuinfo
physical id : 0
siblings : 1
core id : 0
-C n 显示匹配到的字符串所在的行及其前后各n行,C=context
grep -C 2 “core id” /proc/cpuinfo
physical id : 0
siblings : 1
core id : 0
cpu cores : 1
apicid : 0
模式部分:
1.可以用fgrep(fast grep)代替来提高查找速度
2.使用正则表达式
匹配字符:
. :任意一个字符。
[abc] :表示匹配一个字符,这个字符必须是abc中的一个。
[a-zA-Z] :表示匹配一个字符,这个字符必须是a-z或A-Z这52个字母中的一个。
[^123] :匹配一个字符,这个字符是除了1、2、3以外的所有字符。
对于一些常用的字符集,系统做了定义:
[A-Za-z] 等价于 [[:alpha:]]
[0-9] 等价于 [[:digit:]]
[A-Za-z0-9] 等价于 [[:alnum:]]
tab,space 等空白字符 [[:space:]]
[A-Z] 等价于 [[:upper:]]
[a-z] 等价于 [[:lower:]]
标点符号 [[:punct:]]
匹配次数:
{m,n} :匹配其前面出现的字符至少m次,至多n次。
? :匹配其前面出现的内容0次或1次,等价于{0,1}。
* :匹配其前面出现的内容任意次,等价于{0,},所以 “.*” 表述任意字符任意次,即无论什么内容全部匹配。
位置锚定:
^ :锚定行首
$ :锚定行尾。技巧:"^$“用于匹配空白行。
\b或<:锚定单词的词首。如”\blike"不会匹配alike,但是会匹配liker
\b或>:锚定单词的词尾。如"\blike\b"不会匹配alike和liker,只会匹配like
\B :与\b作用相反。
分组及引用:
(string) :将string作为一个整体方便后面引用
\1 :引用第1个左括号及其对应的右括号所匹配的内容。
\2 :引用第2个左括号及其对应的右括号所匹配的内容。
\n :引用第n个左括号及其对应的右括号所匹配的内容。