linux中通配符与正则表达式

1、正在表达式与通配符

  正则表达式用来在文件中匹配符合条件的字符串

  正则是包含匹配,grep、awk、sed等命令可以支持正则表达式。

  通配符是完全匹配,用来匹配符合条件的文件名ls、find、cp这些命令不支持正则表达式。

2、正在表达式符号

*   前一个字符匹配0次或任意多次。

.   匹配除了换行符外任意一个字符。

^   匹配行首。例如:^hello会匹配以hello开头的行。

$   匹配行尾。例如:hello$会匹配以hello结尾的行。

[]   匹配中括号中指定的任意一个字符。[0-9]匹配任意一位数字,[a-z][0-9]匹配小写和一位数字构成的两位字符。

[^]  匹配除中括号以外任意一个字符例如:[^0-9]匹配任意一位非数字字符 [^a-z]匹配任意一位非小写字母。

\   转义符。取消字符的特殊含义。

\{n\}    前面的字符恰好出现n次。例如:[0-9]\{4\}匹配4位数字。

\{n,\}   前面的字符出现不小于n次。例如:[0-9]\{2,\}表示两位及以上的数字。

\{n,m\}   前面的字符至少出现n次,最多出现m次,例如:[a-z]\{6,8\}匹配6到8位的小写字母。

3、正在表达式举例

grep "a*" test.txt        匹配所有内容,包括空白行

grep "aa*" test.txt       匹配至少包含一个a的行

grep "aaa*" text.txt       匹配至少包含两个连续a的字符串

grep "aaaaa*" text.txt     匹配至少包含4个连续a的字符串

grep "s..d" text.txt       匹配s和d之间有两个字符的字符串

grep "s.*d" text.txt       匹配s和d之间有任意字符的字符串

grep ".*" text.txt         匹配任意字符串

grep "^M" text.txt         匹配以M开头的行

grep "n$" text.txt         匹配以n结尾的行

grep -n "^$" text.txt      匹配空白行

grep "s[ao]id" text.txt    匹配s和i之间要么是a要么是o

grep "[0-9]" text.txt      匹配任意一个数字

grep "^[a-z]" text.txt     匹配用小写字母开头的行

grep "^[^a-z]" text.txt    匹配不用小写字母开头的行

grep "^[^a-zA-Z]" text.txt  匹配不用字母开头的行

grep "\.$" text.txt         匹配使用"."结尾的行

grep "a\{3\}" text.txt      匹配a字母连续出现三次的字符串

grep "[0-9]\{3\}" text.txt  匹配包含连续的三个数字的字符串

grep "^[0-9]\{3,\}[a-z]" text.txt     匹配最少用连续3个数字开头的行

grep "sa\{1,3\}i" text.txt            匹配在字母s和字母i之间有最少1个a,最多3个a

 

posted @ 2019-07-09 08:16  雷雨客  阅读(247)  评论(0编辑  收藏  举报