Linux/Unix 系统中find命令用法
liuian 2025-05-23 18:31 90 浏览
find 是 Linux/Unix 系统中一个非常强大且灵活的命令,用于在目录层次结构中查找文件和目录。它允许你根据各种条件(如名称、类型、大小、权限、修改时间等)来搜索,并对找到的结果执行操作。
基本语法
find [path...] [expression]
[path...]: 指定一个或多个起始目录进行搜索。如果省略,则默认为当前目录 (.)。
[expression]: 由选项、测试条件和操作组成。
常用选项 (Options)
这些选项影响 find 的整体行为,通常放在表达式的最前面。
-maxdepth levels: 限制搜索的最大深度。levels 为 0 表示仅搜索指定的 path 本身。
-mindepth levels: 限制搜索的最小深度。levels 为 1 表示不搜索指定的 path 本身,只搜索其子目录。
-depth: 优先处理目录内容,然后再处理目录本身。这在某些操作(如删除)中很有用。
-follow: 跟随符号链接(默认不跟随)。
-xdev: 不跨越文件系统边界。
常用测试条件 (Tests)
这些条件用于匹配文件或目录的属性。
1. 按名称/路径匹配:
-name pattern: 按文件名匹配(区分大小写)。pattern 可以使用通配符 (*, ?, [])。例如:*.txt, file?, [abc]file。
注意: pattern 通常需要用引号括起来,以防止 shell 扩展。
-iname pattern: 按文件名匹配(不区分大小写)。
-path pattern: 按完整路径名匹配(包括目录名)。
-ipath pattern: 按完整路径名匹配(不区分大小写)。
-regex pattern: 按完整路径名匹配,使用正则表达式(默认是 Emacs 正则表达式)。
-iregex pattern: 同上,但不区分大小写。
2. 按类型匹配:
-type c: 查找指定类型的文件。c 的值可以是:
f: 普通文件
d: 目录
l: 符号链接
s: 套接字 (socket)
p: 命名管道 (FIFO)
b: 块设备文件
c: 字符设备文件
3. 按时间戳匹配:
n: 表示恰好 n 天/分钟前。
+n: 表示超过 n 天/分钟前。
-n: 表示在 n 天/分钟内。
-atime n: 文件在 n*24 小时前被访问过。
-mtime n: 文件内容在 n*24 小时前被修改过。
-ctime n: 文件元数据 (inode change time) 在 n*24 小时前被改变过。
-amin n: 文件在 n 分钟前被访问过。
-mmin n: 文件内容在 n 分钟前被修改过。
-cmin n: 文件元数据在 n 分钟前被改变过。
-newer file: 查找比 file 更新的文件(基于修改时间)。
4. 按大小匹配:
-size n[cwbkMG]: 查找指定大小的文件。
n: 数值
单位:
c: 字节 (bytes)
w: 字 (2字节)
b: 块 (512字节,默认)
k: 千字节 (KB)
M: 兆字节 (MB)
G: 吉字节 (GB)
+n: 大于 n
-n: 小于 n
n: 等于 n
5. 按权限匹配:
-perm mode: 查找权限恰好为 mode (例如 644, 755) 的文件。
-perm -mode: 查找权限至少包含 mode 中所有位的的文件 (例如 -644 表示权限至少为 rw-r--r--)。这是最常用的。
-perm /mode: 查找权限包含 mode 中任意一位的文件 (例如 /222 表示属主、属组或其他人有写权限)。
6. 按所有者/组匹配:
-user uname: 查找属于用户 uname 的文件。
-uid n: 查找属于用户 ID 为 n 的文件。
-group gname: 查找属于组 gname 的文件。
-gid n: 查找属于组 ID 为 n 的文件。
-nouser: 查找没有有效用户的文件。
-nogroup: 查找没有有效组的文件。
7. 空文件/目录:
-empty: 查找空文件或空目录。
逻辑操作符 (Operators)
用于组合多个测试条件。
-a 或 -and: 逻辑与 (AND)。默认情况下,多个条件之间就是 AND 关系,所以通常省略。
-o 或 -or: 逻辑或 (OR)。
! 或 -not: 逻辑非 (NOT)。
( ): 分组条件。由于括号对 shell 有特殊含义,所以需要转义:\( ... \)。
常用操作 (Actions)
对找到的文件执行的操作。
-print: 将找到的文件路径打印到标准输出(默认操作,如果未指定其他操作)。
-ls: 对找到的文件执行 ls -dils 命令,并显示其详细信息。
-delete: 删除找到的文件。请极其小心使用此操作! 最好先用 -print 确认结果。
-exec command {} \;: 对每个找到的文件执行 command。
{}: 会被替换为当前找到的文件名。
\;: 表示命令结束。注意分号需要转义。
-exec command {} +: 对一批找到的文件执行 command。这比每个文件都启动一次 command 更高效。{} 仍然代表文件名,但会一次传递多个文件名给 command。
-ok command {} \;: 与 -exec 类似,但在执行每个命令前会提示用户确认。
-prune: 如果条件匹配的是目录,则不进入该目录搜索。常用于排除特定目录。
-quit: 找到第一个匹配项后立即退出 find。
实用示例
在当前目录及其子目录中查找所有 .log 文件:
find . -name "*.log"
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
在 /var/www 目录中查找所有名为 index.html 的文件 (不区分大小写):
find /var/www -iname "index.html"
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
查找 /home 目录下所有普通文件:
find /home -type f
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
查找当前目录下所有空目录:
find . -type d -empty
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
查找 /tmp 目录下7天前被修改过的文件:
find /tmp -type f -mtime +7
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
(7天前是指比7*24小时更早)
查找 /tmp 目录下最近24小时内被修改过的文件:
find /tmp -type f -mtime -1
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
查找 /opt 目录下大小超过 100MB 的文件:
find /opt -type f -size +100M
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
查找 /etc 目录下权限为 644 的文件:
find /etc -type f -perm 644
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
查找 /home/user 目录下属于用户 user 且文件名以 .bak 结尾的文件:
find /home/user -user user -name "*.bak"
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
查找当前目录下所有 .jpg 文件,并删除它们 (危险操作!):
# 先确认
find . -name "*.jpg" -print
# 确认无误后执行删除
find . -name "*.jpg" -delete
# 或者使用 -ok 进行逐个确认
find . -name "*.jpg" -ok rm {} \;
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
查找所有 .conf 文件,并更改其权限为 600:
find / -type f -name "*.conf" -exec chmod 600 {} \;
# 更高效的方式 (如果 chmod 支持一次处理多个文件):
find / -type f -name "*.conf" -exec chmod 600 {} +
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
查找当前目录下不是 .txt 结尾的文件:
find . -type f -not -name "*.txt"
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
查找 /data 目录下所有 .log 文件或 .txt 文件:
find /data -type f \( -name "*.log" -o -name "*.txt" \)
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
查找当前目录下的 .git 目录并排除,然后查找其他所有 .md 文件:
find . -name ".git" -prune -o -name "*.md" -print
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
这里 -prune 会阻止 find 进入 .git 目录。-o 之后的 -name "*.md" -print 会在其他路径下查找。
查找 /var/log 下所有 .log 文件,并用 grep 搜索包含 "ERROR" 的行:
find /var/log -name "*.log" -type f -exec grep "ERROR" {} \;
# 或者更高效地:
find /var/log -name "*.log" -type f -exec grep "ERROR" {} +
# 如果日志很多,想看到文件名:
find /var/log -name "*.log" -type f -exec grep -H "ERROR" {} +
IGNORE_WHEN_COPYING_START
content_copy
download
Use code with caution.
Bash
IGNORE_WHEN_COPYING_END
注意事项
性能: 在非常大的目录树中搜索时,find 可能会消耗较多时间和资源。尽量缩小搜索范围,或使用更具体的条件。
-exec vs -exec ... +: 后者通常更高效,因为它会一次性将多个文件名传递给命令,减少了命令启动的次数。但并非所有命令都支持一次处理多个文件参数。
引号: 当 pattern 中包含通配符或特殊字符时,务必使用引号(单引号或双引号)将其括起来,以防止 shell 在 find 命令执行前就对其进行扩展。
权限: 如果你没有权限访问某些目录,find 会输出错误信息。可以使用 2>/dev/null 将错误信息重定向,或者使用 sudo (如果必要且有权限)。
find 命令非常强大,通过组合不同的选项、测试条件和操作,可以实现非常复杂的查找和处理任务。建议多加练习以熟练掌握。
相关推荐
- 教你把多个视频合并成一个视频的方法
-
一.情况介绍当你有一个m3u8文件和一个目录,目录中有连续的视频片段,这些片段可以连成一段完整的视频。m3u8文件打开后像这样:m3u8文件,可以理解为播放列表,里面是播放视频片段的顺序。视频片段像这...
- 零代码编程:用kimichat合并一个文件夹下的多个文件
-
一个文件夹里面有很多个srt字幕文件,如何借助kimichat来自动批量合并呢?在kimichat对话框中输入提示词:你是一个Python编程专家,完成如下的编程任务:这个文件夹:D:\downloa...
- Java APT_java APT 生成代码
-
JavaAPT(AnnotationProcessingTool)是一种在Java编译阶段处理注解的工具。APT会在编译阶段扫描源代码中的注解,并根据这些注解生成代码、资源文件或其他输出,...
- Unit Runtime:一键运行 AI 生成的代码,或许将成为你的复制 + 粘贴神器
-
在我们构建了UnitMesh架构之后,以及对应的demo之后,便着手于实现UnitMesh架构。于是,我们就继续开始UnitRuntime,以用于直接运行AI生成的代码。PS:...
- 挣脱臃肿的枷锁:为什么说Vert.x是Java开发者手中的一柄利剑?
-
如果你是一名Java开发者,那么你的职业生涯几乎无法避开Spring。它如同一位德高望重的老国王,统治着企业级应用开发的大片疆土。SpringBoot的约定大于配置、SpringCloud的微服务...
- 五年后,谷歌还在全力以赴发展 Kotlin
-
作者|FredericLardinois译者|Sambodhi策划|Tina自2017年谷歌I/O全球开发者大会上,谷歌首次宣布将Kotlin(JetBrains开发的Ja...
- kotlin和java开发哪个好,优缺点对比
-
Kotlin和Java都是常见的编程语言,它们有各自的优缺点。Kotlin的优点:简洁:Kotlin程序相对于Java程序更简洁,可以减少代码量。安全:Kotlin在类型系统和空值安全...
- 移动端架构模式全景解析:从MVC到MVVM,如何选择最佳设计方案?
-
掌握不同架构模式的精髓,是构建可维护、可测试且高效移动应用的关键。在移动应用开发中,选择合适的软件架构模式对项目的可维护性、可测试性和团队协作效率至关重要。随着应用复杂度的增加,一个良好的架构能够帮助...
- 颜值非常高的XShell替代工具Termora,不一样的使用体验!
-
Termora是一款面向开发者和运维人员的跨平台SSH终端与文件管理工具,支持Windows、macOS及Linux系统,通过一体化界面简化远程服务器管理流程。其核心定位是解决多平台环境下远程连接、文...
- 预处理的底层原理和预处理编译运行异常的解决方案
-
若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好![Mac-10.7.1LionIntel-based]Q:预处理到底干了什么事情?A:预处理,顾名思义,预先做的处理。源代码中...
- 为“架构”再建个模:如何用代码描述软件架构?
-
在架构治理平台ArchGuard中,为了实现对架构的治理,我们需要代码+模型描述所要处理的内容和数据。所以,在ArchGuard中,我们有了代码的模型、依赖的模型、变更的模型等,剩下的两个...
- 深度解析:Google Gemma 3n —— 移动优先的轻量多模态大模型
-
2025年6月,Google正式发布了Gemma3n,这是一款能够在2GB内存环境下运行的轻量级多模态大模型。它延续了Gemma家族的开源基因,同时在架构设计上大幅优化,目标是让...
- 比分网开发技术栈与功能详解_比分网有哪些
-
一、核心功能模块一个基本的比分网通常包含以下模块:首页/总览实时比分看板:滚动展示所有正在进行的比赛,包含比分、比赛时间、红黄牌等关键信息。热门赛事/焦点战:突出显示重要的、关注度高的比赛。赛事导航...
- 设计模式之-生成器_一键生成设计
-
一、【概念定义】——“分步构建复杂对象,隐藏创建细节”生成器模式(BuilderPattern):一种“分步构建型”创建型设计模式,它将一个复杂对象的构建与其表示分离,使得同样的构建过程可以创建...
- 构建第一个 Kotlin Android 应用_kotlin简介
-
第一步:安装AndroidStudio(推荐IDE)AndroidStudio是官方推荐的Android开发集成开发环境(IDE),内置对Kotlin的完整支持。1.下载And...
- 一周热门
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)