处理多个文件和目录
递归操作
ls 命令有一个 -R(请注意是大写字母 “R”)选项用于列出目录和它的所有子目录。
cp 可以使用 -r(或 -R或 --recursive)选项让 cp 命令进入来源目录并递归复制内容。要预防无限递归,不能复制来源目录本身。
rm rmdir 命令仅删除空目录。您可以使用 -r(或 -R 或 --recursive)选项让 rm命令同时删除文件和目录。
通配符和 globbing
一个包含字符 “?”、“*” 或 “[” 中的任何一个字符的字符串就是通配符模式。shell(或者可能另一个程序)可以使用 Globbing 过程将这些模式扩展为一组与该模式匹配的路径名。匹配过程是采用以下方式完成的:
- ? 匹配任何单个字符。
- ** * ** 匹配任何字符串,包括空字符串。
- [ 引入一个字符类。字符类是一个非空字符串,以 “]” 终止。匹配表示与括号内的任何单个字符匹配。有一些特殊的考虑因素:
- “*” 和 “?” 字符匹配它们自己。如果在文件名中使用这些字符,您需要注意正确地引用或转义。
- 因为该字符串必须是非空的且以 “]” 终止,因此,如果您想要匹配该字符串,必须先将 “]” 放在字符串中。
- 两个字符之间的 “-” 表示一个范围,其中包含另外两个字符和它们之间的所有字符(按整理顺序排列)。
例如,[0-9a-fA-F] 表示任何大写或小写的十六进制数。您可以将 “-” 放在范围中的开头或末尾来与该字符匹配。 - 指定为范围的第一个字符的 “!” 会对范围进行补足,以便它能与除剩余字符外的任何字符匹配。
例如,[!0-9] 表示除数字 0 到 9 的任何字符。除第一个位置外的任何位置的 “!” 会匹配自己。请记住,“!” 也可与 shell history 函数结合使用,所以您需要小心地正确转义它。
备注:通配符模式和正则表达式模式具有一些相同的特征,但它们并不相同。请特别小心。
ian@Z61t-u14:~/lpi103-2$ echo odd1>'text[*?!1]'
ian@Z61t-u14:~/lpi103-2$ echo odd2>'text[2*?!]'
ian@Z61t-u14:~/lpi103-2$ ls
backup text1 text2 text3 text5 xaa yaa
sedtab text[*?!1] text[2*?!] text4 text6 xab yab
ian@Z61t-u14:~/lpi103-2$ ls text[2-4]
text2 text3 text4
ian@Z61t-u14:~/lpi103-2$ ls text[!2-4]
text1 text5 text6
ian@Z61t-u14:~/lpi103-2$ ls text*[2-4]
text2 text[2*?!] text3 text4
ian@Z61t-u14:~/lpi103-2$ ls text*[!2-4]* # Surprise!
text1 text[*?!1] text[2*?!] text5 text6
ian@Z61t-u14:~/lpi103-2$ ls text*[!2-4] # Another surprise!
text1 text[*?!1] text[2*?!] text5 text6
ian@Z61t-u14:~/lpi103-2$ echo text*>text10
ian@Z61t-u14:~/lpi103-2$ ls *\!*
text[*?!1] text[2*?!]
ian@Z61t-u14:~/lpi103-2$ ls *[x\!]*
text1 text10 text[2*?!] text4 text6 xab text[*?!1] text2 text3 text5 xaaian@Z61t-u14:~/lpi103-2$ ls *[y\!]*
text[*?!1] text[2*?!] yaa yab
ian@Z61t-u14:~/lpi103-2$ ls tex?[[]*
text[*?!1] text[2*?!]
ian@Z61t-u14:~/lpi103-2$ rm tex?[[]*
ian@Z61t-u14:~/lpi103-2$ ls *b*
sedtab xab yab
backup:
text1.bkp.1 text1.bkp.2
ian@Z61t-u14:~/lpi103-2$ ls backup/*2
backup/text1.bkp.2
ian@Z61t-u14:~/lpi103-2$ **ls -d .*