正则表达式:REGularEXPression,==>REGWXP
. //匹配任意字符
* //匹配当前字符任意次
.* //匹配任意长度的任意字符
\? //匹配其前面的字符1次或0次
\{m,n\} //匹配前面的字符最少m次最多n次
//如果没有上限,n可以省略
正则表达式在默认的情况下工作在贪婪模式下,也就是说它会尽可能的去匹配
例:grep'a\{1,2\}b' //找到以a最少出现一次,最多出现两次的字符,并且一
//b结尾
^ //锚定行首,此字符后面的任意内容必须出现在行首
$ //锚定行尾,此字符后面的任意内容必须出现在行尾
^$ //匹配空白行
[] //匹配指定范围内的任意单个字符
[^] //匹配指定范围外的任意单个字符
字符集合
[:digit:] //数字
[:loeer:] //小写字母
[:upper:] //大写字母
[:punct:] //标点符号
[:space:] //空格
[:alpha:] //所有字母
[:alnum:] //所有数字和字符
\<或\b //锚定词首,其后面的任意字符必须作为单词的首部出现
\>或\b //锚定词尾,其前面的任意字符必须作为单词的尾部出现
\<root\> //精确查找root
分组
\(\)
\(ab\)* //的意思是*修饰的是ab这一个整体
//分组的意义,用括号扩起来的内容,可以作为后面的引用,称为后向引用
\1 //表示第一个左括号以及对应的右括号所包含的所有内容
\2
\3
例:grep'\(l..e\).*\1' txt.txt //意思是讲匹配以l开始任意两个字符
//以e结尾。.*表示匹配前面分组的任意字符,任意次,\1表示与分组
//相同的匹配
默认情况下只支持基本的正则表达式
-i //忽略字符大小写
-v //反响输出
-o //只显示匹配到的字符串
-E //使用扩展正则表达式
-A //当某一行被匹配到了,它会显示当前匹配行,也会显示指定当前行的
//后n行
-B //与-A相反,显示前两行
-C //结合了A B显示前后两行
扩展的正则表达式:EREGEXP
+ //其前面的字符至少一次
? //与\?一样
{m,n} //至少m此,至多n次
分组不需要加\
() //分组
或者
a|b //表示或者a或者b
例:C|cat //C或者cat
例:'(C|c)ab' //Cat或者cat
Fgrep :不支持正则表达式