正则表达式
首先,大家如果看到有什么不懂的地方,欢迎吐槽!!!
我会在当天或者第二天及时回复,并且改进~~
普通字符:只是字面的意思
元字符 :超过字面意思的意义
基本正则表达式元字符及其意义
*: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}