1.第一关:本次挑战中有一些带有不同文件扩展名的文件。请递归删除当前工作目录中所有扩展名为.doc 的文件
bashfind . -type f -name "*.doc" -delete解析:
find:就是 "查找" 的意思,专门用来在电脑里找文件或文件夹。.:代表 "当前文件夹"(你现在打开的这个文件夹)。-type f:只找 "文件"(排除文件夹,避免误删文件夹)。-name "*.doc":只找名字符合 "随便什么字符 + .doc" 的文件(比如报告.doc、notes123.doc都算)。-delete:找到符合条件的文件后,直接删掉它们。
2.第二关:当前工作目录中有一个名为 access.log 的文件。请打印该文件中所有包含字符串 "GET" 的行
bashgrep "GET" access.log解析:
grep就像 "搜索小助手",专门在文件里找包含特定内容的行。"GET"是要找的目标内容(这里就是 "GET" 这个词)。access.log是要搜索的文件(就是当前文件夹里叫 access.log 的那个文件)。
3.第三关:打印当前目录下所有包含字符串 "500" 的文件,每个文件名单独占一行(只显示文件名,不显示路径)
bashgrep -l "500" *解析:
grep:负责在文件里搜索内容的工具。-l(小写 L):这个选项表示 "只显示包含目标内容的文件名",而不是显示具体的行。-l是--files-with-matches这个长选项的缩写,对应的单词是list(列表、列出)。它的设计逻辑是:当你用grep搜索内容时,默认会显示 "包含匹配内容的行";而加上-l后,它就不再显示具体的行,而是只列出 "包含匹配内容的文件名列表" ------ 相当于告诉grep:"不用给我看具体内容了,把符合条件的文件名字列出来就行"。"500":要搜索的目标字符串。*:代表当前目录下的所有文件(不包含子目录里的文件,只看当前目录)。
4.第四关:打印当前目录下所有文件名以 "access.log" 开头的文件的相对路径,每个路径单独占一行。
bashfind . -name "access.log*"解析:
- find:专门用来找文件的位置
- .:表示当前目录
- -name "access.log*":表示要找名字以access.log开头的文件
思考:
为什么不是只显示文件名? 因为
find设计的初衷是 "定位文件在哪里",而不仅仅是 "叫什么名字"。如果只显示文件名,当不同目录下有同名文件时(比如子目录里也有access.log),你就分不清它们的位置了。相对路径既保留了文件名,又明确了文件在当前目录下的位置,更实用。
find命令的默认行为:find是用来 "查找文件并显示其完整位置" 的工具。它的输出默认会包含从起始目录开始的路径,而不只是光秃秃的文件名。这里的起始目录是
.(当前目录),所以输出的就是 "当前目录 + 文件名" 的组合,也就是相对路径。