cos_shell编程-正则表达式
正则表达式与通配符
- 正则表达式用来在文件中匹配符合条件的字符串,正则是包含匹配(类似于模糊匹配)。 Grep、awk、sed等命令可支持正则表达式
- 通配符用来匹配符合条件的文件名,通配符是完全匹配。ls、find、cp等命令不支持正则表达式,只能用shell自带的通配符进行匹配
基础正则表达式
元字符 | 作用 |
---|---|
* |
前一个字符匹配0次或任意多次 |
. |
匹配除了换行符外任意一个字符 |
^ |
匹配行首。例:^hello 会匹配以hello开头的行 |
$ |
匹配行尾。例:hello$ 会匹配以hello结尾的行 |
[ ] |
只匹配括号其中任意一个字符。 例如: [abcd] 匹配其中任意一个字母,[1234] 匹配其中任意一个数字,[a-z] [0-9] 匹配其中任意一位小写字母和一位数字构成的两位字符 |
[^] |
匹配除了括号中的字符以外的任意一个字符; 例: [^0-9] 匹配任意一位非数字字符,[^a-z] 匹配任意一位非小写字母字符 |
\ |
转义符,用来取消特殊符号的含义 |
\{n\} |
表示其前面的字符恰好出现的次数, 例: [0-9]\{4\} 匹配4位数字,[1][3-8][0-9]\{9\} 匹配手机号码 |
\{n,\} |
表示其前面的字符出现不小于n次,例:[0-9]\{2,\} 表示两位及以上的数字 |
\{n,m\} |
表示其前面的字符出现至少n次,出现最多m次。例:[a-z]\{3,6\} 表示匹配3到6位的小写字母 |
示例:
- “
*
”前一个字符匹配0次或任意多次
① >grep “c*”test_rule.txt
#匹配所有内容,包括空白行
② >grep “ac*”test_rule.txt
#匹配至少包含一个a的行
③ >grep “aac*”test_rule.txt
#匹配至少包含两个连续a的字符串
④ >grep “bbbbz*”test_rule.txt
#匹配至少包含四个连续b的字符串
- “
.
”匹配除了换行符外任意一个字符
① >grep “s..d”test_rule.txt
#匹配在s和d两个之间一定有两个字符的单词
② >grep “s.*d”test_rule.txt
#匹配在s和d两个之间有任意字符
③ >grep “.*”test_rule.txt
#匹配所有内容
- “
[ ]
”只匹配括号其中任意一个字符
① >grep “s [ ao ]id”test_rule.txt
#匹配在a和o字母中其中任意一个
② >grep “[0-9]”test_rule.txt
#匹配任意一个数字
③ >grep “^[a-z]”test_rule.txt
#匹配用小写字母开头的行
- “
[^]
”匹配除了括号中的字符以外的任意一个字符;
① >grep “^ [^a-z]”test_rule.txt
#匹配不是小写字母开头的行
② >grep “^[^a-zA-Z]”test_rule.txt
#匹配不是字母开头的行
- “
\
”转义符
① >grep “\.$”test_rule.txt
#匹配不是以“.”结尾的行
- “
\{n\}
”表示其前面的字符恰好出现的次数
① >grep “a\{3\}”test_rule.txt
#匹配字母a连续出现3次的字符串
② >grep “[0-9]\{3\}”test_rule.txt
#匹配出现包含连续三个数字的字符串
- “
\{n,\}
”表示其前面的字符出现不小于n次
① >grep “^[0-9]\{3,\}[a-z]”test_rule.txt
#匹配至少三个连续数字开头的行
- “
\{n,m\}
”表示其前面的字符出现至少n次,出现最多m次
① >grep “sa\{1,3\}z”test_rule.txt
#匹配在字母s和z之间有最少一个a,最多三个a的字符串
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 some森!