Linux进阶命令-grep
Linux进阶命令----grep
grep 命令介绍
Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。
grep全称是Global Regular Expression Print,表示全局正则表达式版本。
它的使用权限是所有用户。
grep命令格式
grep [选项] [文本内容] 文件名
常用选项
- 
-E :开启扩展(Extend)的正则表达式。 
- 
-i :忽略大小写(ignore case)。 
- 
-v :反过来(invert),只打印没有匹配的,而匹配的反而不打印。 
- 
-n :显示行号 
- 
-w :被匹配的文本只能是单词,而不能是单词中的某一部分,如文本中有liker,而我搜寻的只是like,就可以使用-w选项来避免匹配liker 
- 
-c(count·) :显示总共有多少行被匹配到了,而不是显示被匹配到的内容,注意如果同时使用-cv选项是显示有多少行没有被匹配到。 
- 
-o :只显示被模式匹配到的字符串。 
- 
-e : 匹配多个文本 
- 
-l : 显示含有匹配文字的文件的文件名 
- 
--color :将匹配到的内容以颜色高亮显示。 
- 
-A n:显示匹配到的字符串所在的行及其后n行,after 
- 
-B n:显示匹配到的字符串所在的行及其前n行,before 
- 
-C n:显示匹配到的字符串所在的行及其前后各n行,context 
模式部分
1、直接输入要匹配的字符串,这个可以用fgrep(fast grep)代替来提高查找速度,比如我要匹配一下hello.c文件中printf的个数:grep -c "printf" hello.c
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,\},所以 ".*" 表述任意字符任意次,即无论什么内容全部匹配。
位置锚定:
^ :锚定行首
$ :锚定行尾。技巧:"^$"用于匹配空白行。
 
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号