提示:本文最后更新于2022⑴2⑵3 22:31,文中所关联的信息可能已产生改变,请知悉!
linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。
grep [OPTION]…PATTERN [FILE] …
[options]主要参数:
-c:只输出匹配了多少次。
-i:不辨别大小写(只适用于单字符)。
-h:查询多文件时不显示文件名。
-l:查询多文件时只输出包括匹配字符的文件名。
-n:显示匹配行及行号。
-s:不显示不存在或无匹配文本的毛病信息。
-v:显示不包括匹配文本的所有行。
-d:跳过对子目录的搜索
-r: 对子目录也进行查找
-E: 将样式为延伸的正则表达式来使用
-o:只显示匹配PATTERN 部份。
\:疏忽正则表达式中特殊字符的原有含义。
^:匹配正则表达式的开始行,如:’^grep’匹配所有以grep开头的行。
$: 匹配正则表达式的结束行,如’grep$’匹配所有以grep结尾的行。
\<:从匹配正则表达式的行开始。如’\<grep’匹配包括以grep结尾的单词的行。
\>:到匹配正则表达式的行结束。如’grep\>’匹配包括以grep结尾的单词的行。
[]:匹配一个指定范围内的字符,如'[Gg]rep’匹配Grep和grep。需要特別留意的是,在 [] 当中『仅代表一个待搜索的字元』
[ n1-n2 ]:范围,如[A-Z],即A、B、C一直到Z都符合要求 。
.:所有的单个字符。
*:有字符,长度可以为0。
\(..\):标记匹配字符,如'(love)’,love被标记为1。
\{n,m\}:意義:重复前一个字符n-m个,若为\{n\}则是重复前一个字符n次,若是 \{n,\}则是重复前一个字答n次以上
+ 匹配一个或多个先前的字符。如:'[a-z]+able’,匹配一个或多个小写字母后跟able的串,如loveable,enable,disable等。
? 匹配零个或多个先前的字符。如:’gr?p’匹配gr后跟一个或没有字符,然后是p的行。
a|b|c 匹配a或b或c。如:grep|sed匹配grep或sed
() 分组符号,如:love(able|rs)ov+匹配loveable或lovers,匹配一个或多个ov。
参数不举例了,见名思义,下面主要练习正则表达式
1)正则表达式的应用(过滤出本机IP地址)
ifconfig eth0|grep ‘inetaddr:’|sed ‘s/^.*addr:\([0⑼]\{1,3\}\.[0⑼]\{1,3\}\.[0⑼]\{1,3\}\.[0⑼]\{1,3\}\) Bcast.*/\1/g’
10.0.0.29
解析:^.* 以任意字符开头,并重复0次或屡次
[0⑼]\{1,3\} 重复匹配0⑼中的字符1次或2次或3次
\(……\) 标记匹配字符,第一个\(\)标记为1,第二个\(\)标记为2
\1 取第1个标记中的内容
s/aa/b/g 属于sed中的替换功能,把aa替换为b,例中把匹配的一行替换为标记1中的内容
2)egrep扩大表达式应用
过滤出多个行要使用egrep
[[email protected]]# ifconfig eth0|grep ‘inet|inet6’
[r[email protected]]# ifconfig eth0|egrep ‘inet|inet6’
inet addr:10.0.0.29 Bcast:10.0.0.255 Mask:255.255.255.0
inet6 addr:fe80::20c:29ff:fe6a:4121/64 Scope:Link
其它+? ()同理,需要使用egrep或grep -E
转载自:https://blog.51cto.com/yangrong/1541927,并修改。
桂%哥%网%络www.guIgege.cn
TikTok千粉号购买平台:https://tiktokusername.com/
TOP