################################################
基本正则表达式:grep 使用正则表达式定义的模式来过滤文本
grep
-i :不区分大小写
--color
-v:显示没被匹配的任意行
-o:只显示被匹配的字符串
-E 扩展的正是表达式 =egerp
-A#:#为数字
-B#:
-C#:
[root@Jameszhan testcp]# grep -o 'root' /etc/passwd --color
root
root
root
root
元字符:
.:匹配任意单个字符
[]:匹配指定范围内的单个字符
[^]:匹配指定范围外的任意单个字符
匹配次数:
*:匹配前面的字符任意次
.*:匹配任意字符串
\? 匹配前面的字符1次或0次
\{m,n\}:匹配前面字符m-n次
位置锚地
^:锚定行首
\<或\b:锚定词首 后面的任意字符必须作为单词首部出现
\<root
$:锚定行尾
\>或\b:锚定词尾 前面的任意字符作为单词出现在尾部
root\>
\(abc\) 作为内容出现和扩展正则表达式雷同
支持后向引用
################################################
扩展的正则表达式:REGular expression regexp
元字符:
.:匹配任意单个字符
[]:匹配指定范围内的单个字符
[^]:匹配指定范围外的任意单个字符
匹配次数:
*:匹配前面的字符任意次
.*:匹配任意字符
\? 匹配前面的字符1次或0次
+:匹配前面的字符至少1次
{m,n}:匹配前面字符
[root@Jameszhan ~]# cat /tmp/t.txt
it is open no opening
###########
位置锚地
^:锚定行首
###########
$:锚定行尾
###########
^$:空白行
###########
\<或\b:锚定词首 后面的任意字符必须作为单词首部出现
\<root
###########
\>或\b:锚定词尾 前面的任意字符作为单词出现在尾部
root\>
###########
(ab)* 分组(一般作为单词出现时用括号扩起来)
[root@Jameszhan ~]# grep '(abc)*' -E --color /tmp/t.txt
ab
abc
aab
aaac
支持后向引用 \1,\2
[root@Jameszhan ~]# grep -E '(open).*\1' /tmp/t.txt --color
it is open no opening
###########
|:或or
用整整表达式写出 1-255
\<[1-9]|[1-9][0-9]|1[0-9][0-99]|2[0-4][0-9]|25[0-5]\>
筛选出网卡配置文件内的0-255之间的数字
ifconfig | grep -E '(\<[0-9]|[1-9][0-9]|1[0-9][0-99]|2[0-4][0-9]|25[0-5]\>)' --color
[root@Jameszhan ~]# cat /etc/passwd | grep 'nologin\>' --color
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin