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}

좋은 웹페이지 즐겨찾기