如何基于通配符匹配递归查找当前和子文件夹中的所有文件?


当前回答

这将搜索当前目录和子目录中的所有相关文件,分别计算它们的行数以及总数:

find . -name "*.wanted" | xargs wc -l

其他回答

你也可以使用ripgrep。

例子:

搜索所有包含子字符串psql的文件名,

rg --files | rg psql

这将搜索当前目录和子目录中的所有相关文件,分别计算它们的行数以及总数:

find . -name "*.wanted" | xargs wc -l

通过管道找到grep通常更方便;它为您提供了用于任意通配符匹配的正则表达式的全部功能。

例如,要查找文件名中不区分大小写字符串“foo”的所有文件:

find . -print | grep -i foo

find将查找与模式匹配的所有文件:

find . -name "*foo"

但是,如果您需要图片:

tree -P "*foo"

递归搜索文件的默认方法,在大多数情况下可用的方法是

find . -name "filepattern"

它开始从您所在的当前目录中递归遍历文件名或模式。使用find命令,可以使用通配符和各种开关。要查看选项的完整列表,请键入

man find

或者如果系统中没有手册页:

find --help

然而,还有比find更现代、更快的工具,它们可以遍历整个文件系统并为文件编制索引。一种常见的工具是locate或slocate/mlocate。您应该查看操作系统的手册,了解如何安装它,一旦安装完成,就需要启动数据库。如果安装脚本不适合您,可以通过键入

sudo updatedb

并且,要使用它查找某些特定文件,请键入:

locate filename

或者,要在当前目录中查找文件名或模式,可以键入:

pwd | xargs -n 1 -I {} locate "filepattern"

它将查看其文件数据库,并快速打印出与您键入的模式匹配的路径名。要查看查找选项的完整列表,请键入:locate--帮助或手动定位

此外,您可以将locate配置为通过cron作业在计划时间更新其数据库,因此在凌晨1点更新数据库的示例cron如下所示:

0 1 * * * updatedb

这些cron作业需要由root配置,因为updatedb需要root权限才能遍历整个文件系统。