grep命令

grep的规则表达式(正则一定要转义)

1
2
3
^    #锚定行的开始 如:'^grep'匹配所有以grep开头的行。   
$    #锚定行的结束 如:'grep$'匹配所有以grep结尾的行。
.    #匹配一个非换行符的字符 如:'gr.p'匹配gr后接一个任意字符,然后是p。
1
2
3
4
5
6
7
8
9
10
11
12
13
*    #匹配零个或多个先前字符 如:'*grep'匹配所有一个或多个空格后紧跟grep的行。 
.*   #一起用代表任意字符。  
[]   #匹配一个指定范围内的字符,如'[Gg]rep'匹配Grep和grep。   
[^]  #匹配一个不在指定范围内的字符
(..)  #标记匹配字符,如'(love)',love被标记为1。   
<      #锚定单词的开始,如:'<grep'匹配包含以grep开头的单词的行。   
>      #锚定单词的结束,如'grep>'匹配包含以grep结尾的单词的行。   
x{m}  #重复字符x,m次,如:'0{5}'匹配包含5个o的行。   
x{m,} #重复字符x,至少m次,如:'o{5,}'匹配至少有5个o的行。   
x{m,n}#重复字符x,至少m次,不多于n次,如:'o{5,10}'匹配5--10个o的行。  
w    #匹配文字和数字字符,也就是[A-Za-z0-9],
W    #w的反置形式,匹配一个或多个非单词字符,如点号句号等。  
    #单词锁定符,如: 'grep'只匹配grep。

grep命令用于在文本中执行关键词搜索。

一般查找

grep  string   files
grepstring”   files
grep  string   files*
grep  string   *files
grep  string   *files*

以递归的方式查找符合条件的文件

grep -r  string   /etc/file

反向查找

通过"-v"参数可以打印出不符合条件行的内容。
查找文件名中包含 test 的文件中不包含test 的行。
grep -v test   files

查找满足字符串的行(第几行满足)

grep -n  string   files

查找满足字符串的行数

grep -c  string   /etc/files

查找时不区分大小写

grep –i "被查找的字符串" 文件名

从文件内容查找与正则表达式匹配的行

grep –e "正则表达式" 文件名

 

 

grep常见命令参数

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
-n  打印行号
    grep -n ".*" h.txt        所有打印行号
    grep -n "root" h.txt    匹配的内容显示行号
-v  不包括
-E  表示过滤 多个参数
    grep -Ev "sshd|network|crond|sysstat|"
-o:仅打印你需要的东西,默认打印正行
     grep -o "hello" h.txt
-i:忽略大小写
    grep -i "hello" h.txt
-c: 用于统计文中出现的次数
--color=auto  过滤字段添加颜色
    利用正则打印特定字符
:作为边界符,边界只包含特定字符的行
    grep "oldboy" /etc/passwd   -->只过滤包含oldboy的行

Linux egrep命令详解

1
2
3
4
egrep: == grep -E 用于显示文件中符合条件的字符
          env|egrep "USER|MAIL|PWD|LOGNAME"
          用的表达式不一样 ,egerp更加规范
egrep -o "oldboy|hello" h.txt   -->仅仅输出 oldboy 和 hello
以Love开头

grep
"^Love" files grep -e "^Love" files grep ^Love files grep -e ^Love files
以Love结尾

grep  "Love$"  files
grep -e "Love$"  files
常用参数
    -o 只输出匹配的文本行 **VS** -v 只输出没有匹配的文本行
    -c 统计文件中包含文本的次数
            grep -c "text" filename
    -n 打印匹配的行号
    -i 搜索时忽略大小写
    -l 只打印文件名

在多级目录中对文本递归搜索(程序员搜代码的最爱)::
    grep "class" . -R -n

匹配多个模式::   
    grep -e "class" -e "vitural" file    

匹配以l开头,中间包含两个字符,结尾是e的所有行

 匹配0个或多个空行,后面是love的字符

 匹配love或Love

 匹配A-Z的字母,其次是ove

 匹配不在A-Z范围内的任何字符行,所有的小写字符

 匹配love.

 匹配空格

 前面o字符重复2到4次

 重复o字符至少2次

 重复0字符最多2次

 重复前一个字符一个或一个以

 0个或者一个字符

 或,查找多个字符串

 分组过滤匹配

参考:https://juejin.im/entry/5ba0c8f86fb9a05d1c14845c

原文地址:https://www.cnblogs.com/ggzhangxiaochao/p/13098475.html