Shell基础之-正则表达式

正则表达式

首先,大家如果看到有什么不懂的地方,欢迎吐槽!!!
我会在当天或者第二天及时回复,并且改进~~

普通字符:只是字面的意思
元字符 :超过字面意思的意义

基本正则表达式元字符及其意义

*:0个或多个在*字符之前的那个普通字符
.               #匹配任意字符
^               #匹配行首
$               #匹配行尾
[]              #匹配字符集合
\               #转义符
\{n\}           #匹配前面字符出现n次
\{n,\}          #匹配前面字符至少出现n次
\{n,m\}         #匹配前面字符出现n-m次 
*  hel*o       #可以匹配helll8o、hello、hellllo
.  ...73.      #可以匹配abc73.、!@#73?、12373c
^  ^...X86*    #可以匹配以abcX86fang开头的字符
$  make$       #表示以make结尾
^$             #表示空行
^.$            #表示某行只有一个字符
[a-z]          #表示a-z所有小写字母
[0-9]          #表示0-9所有数字
[b-q]          #表示b-q字母
[^b-q]         #取反,除了b-q的所有字符
[A-Za-z] [A-Za-z]*  #能匹配任何一个英文单词
\*             #将\后面的元字符转换为字面意思
\<the\>        #精确匹配,只匹配the字符的单词,利用\符号屏蔽<>符号 grep '\<the\>'
\{n\}          #JO\{3\}B 匹配值为JOOOB
\{n,\}         #JO\{3,\}B 匹配值为JOOOB JOOOOB JOOOOOOOB
\{n,m\}        #JO\{3,6\}B 匹配值为JOOOB JOOOOOB JOOOOOOB
[a-z] \{5\}    #hello house whowh 精确匹配5个小写字母
echo [abc]*    #开头为a/b/c的任意多字符的文件
echo [^abc]*   #开头不是a/b/c的任意多字符的文件 
touch {a,b,c}-{1,2,3} #通过穷举来创建文件,每个文件匹配来创建,总共9个文件
!$             #上一条命令中的最后一个参数
;              #表示命令结束

扩展正则表达式元字符及其意义

?               #匹配0个或1个在其之前的那个普通字符
+               #匹配1个或多个在其之前的那个普通字符
()              #表示一个字符集合或用在expr中
|               #表示或,匹配一组可选的字符 
?  JO?B         #匹配JO1B JO@B JO!B ,只匹配一个字符。如果是JOB或JOOOB则不匹配
+  S+EU         #至少匹配前面的字符1次,可以匹配多次
*  S*U          #可匹配S123U SSUU S!@#U SU
()符号和|符号  re(a|e|o)d  #匹配read reed reod

示例:

1、列出所有以.awk结尾的文件  
   ll *.awk
2、列出以0开头,后面跟一个字符且以.pem为后缀的文件 
   ll 0?.pem
3、列出在a-h范围内以字母开头并以.awk结尾的文件
   [a-h]*.awk
4、列出以a-h范围内字母开头且句点后不是以.awk结尾的文件
   [a-h]*.[^awk]*
5、列出满足在a-h范围内以字母开头并以.awk结尾的文件,或列出以0开头,后面跟一个字符且以.pem为后缀的文件
   ll {[a-h]*.awk,0?.pem}

你可能感兴趣的:(shell,正则表达式)