Shell学习之结合正则表达式与通配符的使用

Posted -零

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Shell学习之结合正则表达式与通配符的使用相关的知识,希望对你有一定的参考价值。

 

 

Shell学习之结合正则表达式与通配符的使用

 

目录

通配符

正则表达式

 

 

 通配符

 

 

正则表达式与通配符

 

正则表达式用来在文件中匹配符合条件的字符串,正则是包含匹配。grep、awk、sed等命令可以支持正则表达式。

通配符用来匹配符合条件的文件名,通配符是完全匹配。ls、find、cp这些命令不支持正则表达式,所以只能使用shell自己的通配符来就行匹配。

  

 

通配符

符号	作用
*	匹配任何字符串/文本,包括空字符串;*代表任意字符(0个或多个) ls file *
?	匹配任何一个字符(不在括号内时)?代表人意1个字符 ls file 0
[abcd]	匹配abcd中任何一个字符
[a-z]	表示范围a到z,表示范围的意思 []匹配中括号中任意一个字符 ls file 0
{..}	表示生成序列。以逗号分隔,且不能有空格
补充	 
[!abcd]	或[^abcd]表示非,表示不匹配括号里面的任何一个字符

  

 

通配符的使用

 

? 匹配任何一个字符

ls /bin/???

ls /bin/??

 

 [abcd] 表示匹配中括号内任意一个字符就成

ls te[asb]t

 

 {}生成序列

touch {a..c}

 

匹配文件

ls [a-c]

 

利用{}备份数据库 

表示将ae复制一份叫做affff
cp a{e,fff}

表示将ae做备份叫做ae.bak
cp a{e,e.bak}

  

 

 

!^表示非,取反

查找文件名里没有a和e的文件名
ls [!ae] ls [^ae]

  

 

 

 

正则表达式

 

 

正则表达式

 

 

 

正则表达式的使用

 

"*" 前一个字符匹配0次,或者任意多次

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

匹配至少包含有两个a的行
grep "aaa*"


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

匹配所有内容
grep ".*" test.txt

匹配在s与d之间一定有两个字符的单词
grep "s..d" test.txt

匹配在s与d之间有任意字符
grep "s.*d" test.txt


"^"匹配行首,"$"匹配行尾

匹配空白行
grep "^$" test.txt

匹配以大写字母M开头的行
grep "^M" test.txt

匹配以小写字母m结尾的行
grep "m$" test.txt



"[]\'匹配中括号中指定的任意一个字符,只匹配一个字符
匹配s和i字母中,要不是a、要不是b
grep "s[ao]id" test.txt

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

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



"[^]"匹配除中括号的字符以外的任意一个字符
匹配不用小写字母开头的行
grep "[^a-z]" test.txt

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


"\\" 转义符
匹配以点结尾的行
grep "\\.$" test.txt


"\\{n\\}" 表示其前面的字符恰好出现n次

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

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


"\\{n,\\}" 表示其前面的字符出现不小于n次

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



"\\{n,m\\}\'匹配其前面的字符至少出现n次,最多出现m次

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

  

以上是关于Shell学习之结合正则表达式与通配符的使用的主要内容,如果未能解决你的问题,请参考以下文章

shell学习之正则表达式基础篇

[Shell]正则表达式与通配符

linux通配符

正则表达式与Linux通配符

shell正则表达式

Linux07--Shell程序设计03 通配符与正则表达式