grep
grep [选项] ”模式“ [文件]
主要选项有:
- -E :开启扩展(Extend)的正则表达式。
- -i :忽略大小写(ignore case)。
- -v :反过来(invert),只打印没有匹配的,而匹配的反而不打印。
- -c :显示总共有多少行被匹配到了,而不是显示被匹配到的内容,注意如果同时使用-cv选项是显示有多少行没有被匹配到。
- -n :显示行号
- -A n:显示匹配到的字符串所在的行及其后n行,after
- -B n:显示匹配到的字符串所在的行及其前n行,before
- -C n:显示匹配到的字符串所在的行及其前后各n行,contex
- -r 或 --recursive : 此参数的效果和指定"-d recurse"参数相同。
grep -n root /etc/passwd
grep root /etc/passwd
grep -C 1 root /etc/passwd
grep -c root /etc/passwd
grep -vc root /etc/passwd
grep -r root /etc/
grep -r root /etc/ |more
grep模式部分:
- . :任意一个字符。
- [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:]]
grep匹配次数:
- {m,n} :匹配其前面出现的字符至少m次,至多n次。
- ? :匹配其前面出现的内容0次或1次,等价于{0,1}。
- :匹配其前面出现的内容任意次,等价于{0,},所以 “.*” 表述任意字符任意次,即无论什么内容全部匹配。
下面是匹配ip地址的代码
netstat -alpt |grep "[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}"
位置锚定
- ^ :锚定行首
- $ :锚定行尾。技巧:"^$"用于匹配空白行。
- \b或<:锚定单词的词首。如"\blike"不会匹配alike,但是会匹配liker
- \b或>:锚定单词的词尾。如"\blike\b"不会匹配alike和liker,只会匹配like
- \B :与\b作用相反。
grep "^ss" /etc/passwd
grep "\bss" /etc/passwd
grep "ss\b" /etc/passwd