grep,egrep及正则表达式详解

前端之家收集整理的这篇文章主要介绍了grep,egrep及正则表达式详解前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

1、定义:
grep:文本搜索工具,根据用户的需要,使用正则表达式,搜索文本并显示匹配到的内容相对应的行。
egrep:文本搜索工具,根据用户的需要,使用扩展正则表达式,搜索文本并显示匹配到的内容相对应的行。
正则表达式:由元字符及正常字符组成,根据用户要求,来实现表达控制和通配功能
2、参数
grep [-oviABCE] [PATTERN] [FILE]...
--color=auto:设置匹配到的字符颜色变化
-o:显示匹配到的行
-v:显示不匹配到的行
-i:不分字母大小写搜索
-A #:显示匹配行外也显示被匹配行后的#行
-B #:显示匹配行外也显示被匹配行前的#行
-C #:显示匹配行外也显示被匹配行前后各#行
-E:扩展正则表达式,等同于 egrep
正则表达示元字符不同的模式:
1.字符匹配:
.:匹配任意单个字符
[]:匹配范围内的任意单个字符
[^]:匹配范围外的任意单个字符
2.次数匹配:
*:匹配任意长度
\?:匹配0次或1次
\+:匹配至少1次
\{m\}:匹配m次
\{m,n\}:匹配至少m次,至多n次
3.位置锚定:
^:锚定行首
$:锚定行尾
4.单词锚定:
\<:锚定词首
\>:锚定词尾
5.分组:
\(\) \1 \2...:分组模式
3、例题:
1、找出/etc/passwd文件中的一位数或两位数;

wKiom1UdPvqhlIr-AAC0FPqRHfE018.jpg

另一种方法

wKioL1UdVnnDGHr-AAC3mbt4mK4166.jpg

2、显示/boot/grub/grub.conf中以至少一个空白字符开头的行;

wKiom1UdPs3CyrxxAACJRTxb3ac090.jpg

3、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行;

wKiom1UdQL3SiCxBAADWFzKo0Us332.jpg

4、打出netstat -tan命令执行结果中含‘LISTEN’,后或跟空白字符结尾的行;

wKioL1UdSTvT_8FMAAC34r5qzA0063.jpg

5、添加用户bash,ttbash,bashers,nologins (此一个用户的shell为/sbin/nologins),而后找出当前系统上其用户名和默认shell相同的用户的信息;

wKiom1UdR-bgPMjsAAGsK9F5drA548.jpg

难点:易把[[:alnum:]]后跟* 这样就代表空字符也在内,并且要加词尾符,要不用户名和SHELL只要有一个单词一样就会匹配。

原文链接:https://www.f2er.com/regex/360596.html

猜你在找的正则表达式相关文章