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