一、Linux shell通配符(wildcard)
通配符是由shell处理的(不是由所涉及到命令语句处理的,其实我们在shell各个命令中也没有发现有这些通配符介绍), 它只会出现在命令的“参数”里(它不用在命令名称里,也不用在操作符上)。当shell在“参数”中遇到了通配符时,shell会将其当作路径或文件名去在磁盘上搜寻可能的匹配:若符合要求的匹配存在,则进行替换(路径扩展);否则就将该通配符作为一个普通字符传递给“命令”,然后再由命令进行处理。
总之,通配符实际上就是一种shell实现的路径扩展功能。在通配符被处理后, shell会先完成该命令的重组,然后再继续处理重组后的命令,直至执行该命令。
例如以下命令:
[root@localhost wildcard]# ls
a.htm b.htm
[root@localhost wildcard]# ls *.htm
a.htm b.htm
[root@localhost wildcard]# ls d*.htm
ls: d*.htm: 没有那个文件或目录
分析如下:
第2个命令中,对于参数*.htm,shell在当前目录下能搜索到相匹配文件,会换成a.htm b.htm。实际执行的是ls a.htm b.htm命令。
第3个命令,对于参数d*.htm, shell在当前目录找不到相匹配的文件,则直接将d*.htm作为ls参数,实际执行的是ls d*.htm。由于找不到该文件,所以会出现:没有那个文件或目录。
了解了shell通配符,我们现在看下,shell常见通配符有那一些了。
shell通配符
字符含义实例* 匹配0或多个字符 a*b a与b之间可以有任意长度的任意字符, 也可以一个也没有, 如aabcb, a01b, ab等
? 匹配任意一个字符 a?b a与b之间有且只有一个字符, 可以是任意字符, 如aab, adb, a0b等
[list] 匹配list中的任意单一字符 a[xyz]b a与b之间有且只有一个字符, 且只能是x或y或z, 如: axb, ayb, azb。
[!list] 匹配除list中的任意单一字符 a[!0-9]b a与b之间有且只有一个字符, 但不能是数字, 如axb, aab, a-b等
[c1-c2] 匹配c1-c2中的任意单一字符 a[0-9]b a与b之间有且只有一个字符,该字符是0-9之间的数字,如a0b, a1b,... ,a9b。
{string1,string2,...} 匹配 sring1 或 string2 (或更多)其一字符串 a{abc,xyz,123}b a与b之间只能是abc或xyz或123这三个字符串之一。
需要说明的是:通配符看起来有点象正则表达式语句,但是它与正则表达式不同的,不能相互混淆。把通配符理解为shell特殊代号字符就可。
二、shell元字符
shell除了有通配符之外,由shell负责预先先解析后,将处理结果传给命令行之外,shell还有一系列自己的其他特殊字符。
shell元字符
字符说明= 变量名=值,为变量赋值。注意=左右紧跟变量名和值,中间不要有空格
$ 变量值替换,$变量名替换为shell变量的值;为避免在文本连接时混淆,请使用${变量名};$0...$9 代表shell文件的参数。
> prog > file 将标准输出重定向到文件。
>> prog >> file 将标准输出追加到文件。
< prog < file 从文件file中获取标准输入
| 管道命令,例:p1 | p2 将p1的标准输出作为p2的标准输入
& 后台运行命令,最大好处是无需等待命令执行结束,就可以在同一命令行下继续输入命令
() 在子shell中执行命令
{} 在当前shell中执行命令,或用在变量替换的界定范围(例如上面的${变量名}用法)。
; 命令结束符。例如p1;p2表示先执行p1,再执行p2
&& 前一个命令执行成功后,才继续执行下一个命令。例:p1 && p2 ;若p1执行成功后,才执行p2,反之,不执行p2;
|| 前一个命令执行失败后,才继续执行下一个命令。例:p1 || p2 ;若p1执行成功后,不执行p2,反之,才执行p2;
! 执行历史记录中的命令
~ home目录
三、shell转义符
有时候,我们想让通配符,或者元字符变成普通字符。那么这里我们就需要用到转义符了。 shell提供转义符有三种。