如何基于通配符匹配递归查找当前和子文件夹中的所有文件?
当前回答
这将搜索当前目录和子目录中的所有相关文件,分别计算它们的行数以及总数:
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权限才能遍历整个文件系统。
推荐文章
- 如何在Makefile中设置子进程的环境变量
- 如何让“wc -l”打印没有文件名的行数?
- 有效地测试Linux上的端口是否打开?
- 如何从另一个文件A中删除文件B中出现的行?
- 对以制表符分隔的文件进行排序
- Shell脚本删除超过n天的目录
- 使用sudo时未找到命令
- 当有命令行参数时,如何使用GDB分析程序的核心转储文件?
- 如何检查shell脚本中是否存在命令?
- 如何使用查找命令从列表中查找所有具有扩展名的文件?
- 如何强制从另一个SSH会话分离屏幕?
- 如何打破一个循环在Bash?
- 如何将文件指针(file * fp)转换为文件描述符(int fd)?
- Linux Bash中双&和分号有什么区别?
- 如何合并2 JSON对象从2个文件使用jq?