正则表达式用来在文件中匹配符合条件的字符串,正则是包含匹配。grep、awk、sed等命令可以支持正则表达式。
通配符用来匹配符合条件的文件名,通配符是完全匹配。ls、find、cp这些命令不支持正则表达式。
* :前一个字符匹配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位的小写字母。
举例:
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