正则表达式是一个神器,但初学linux时候还有文件名通配这样的东东。今天就总结一下文件名通配,正则表达式,扩展正则表达式之间有什么异同。可能写的不全,求指教。
使用方面:
正则多用来匹配过滤文本内容。
支持命令:
文件处理,查看cp find ls rm mv touch 等一系列的文件匹配查找命令。(和上面说的是一个意思)
正则表达式则用在文本内容处理的各种工具grep,awk,sed,vim末行模式等。
匹配功能上正则规矩多,自然能力更强大,所以就这的区别多点。
匹配规则上相同点:
一.字符匹配:
[:digit:]数字、[:lower:]小写、[:upper:]大写、[:alpha:]字母、[:alnum:]字母数字、[:punct:]标点、[:space:]空格 [xdigit]16进制 两者相同。
[^]括号内除外。[]括号内任一字符匹配。[]内的- ,的使用 两者规则也相同。
二. 次数匹配
在正则中支持次数匹配且分为精确次数和模糊次数,在文件名通配中只支持*。
文件名通配中 ?表示任意单个字符且这个字符会出现一次。 *表示任意字符出现任意次。
正则中 .在表示任意字符,*表示*前面的字符出现任意次。.*表示任意字符出现任意次。?表示前面的字符出现1次或0次,即表示前面的字符可有可无。?需要转义。
三. 位置锚定。
扩展正则和正则的区别。
扩展正则中次数匹配中? + {} 不在需要\ 转义符 。
位置锚定中的单词整体锚定<>都还需要\转义符。
内容分组()也不需要\转义符。
扩展正则中提供了新的匹配规则,或者|。
写完了。