find命令

找出/etc下面,文件容量大于50KB且文件所有者不是root的文件名,并且将文件完整地列出(ls-l)
找出/etc下面,容量大于1500KB以及容量等于0的文件


find /etc -size +50k -a ! -user root -exec ls -ld {} \;
find /etc -size +50k -a ! -user root -type f -exec ls -l {} \;
上面两式均可!注意到 ! ,那个 ! 代表的是反向选择,亦即『不是后面的项目』之意!

find /etc -size +1500k -o -size 0
相对于 -a ,那个 -o 就是或 (or) 的意思

find (查找档案,功能强大,就是耗时间和硬盘):
find [PATH] [option] [action] 档案或目录名称
参数:
1. 与时间有关的参数:
-atime n :n 为数字,意义为在 n 天之前的『一天之内』被 access 过的档案;
-ctime n :n 为数字,意义为在 n 天之前的『一天之内』被 change 过状态的档案;
-mtime n :n 为数字,意义为在 n 天之前的『一天之内』被 modification 过的档案;
-newer file :file 为一个存在的档案,意思是说,只要档案比 file 还要新,
就会被列出来~
2. 与使用者或群组名称有关的参数:
-uid n :n 为数字,这个数字是使用者的账号 ID,亦即 UID ,这个 UID 是记录在
/etc/passwd 里面与账号名称对应的数字。这方面我们会在第四篇介绍。
-gid n :n 为数字,这个数字是群组名称的 ID,亦即 GID,这个 GID 记录在
/etc/group,相关的介绍我们会第四篇说明~
-user name :name 为使用者账号名称喔!例如 dmtsai
-group name:name 为群组名称喔,例如 users ;
-nouser :寻找档案的拥有者不存在 /etc/passwd 的人!
-nogroup :寻找档案的拥有群组不存在于 /etc/group 的档案!
当您自行安装软件时,很可能该软件的属性当中并没有档案拥有者,
这是可能的!在这个时候,就可以使用 -nouser 与 -nogroup 搜寻。
3. 与档案权限及名称有关的参数:
-name filename:搜寻文件名称为 filename 的档案;
-size [+-]SIZE:搜寻比 SIZE 还要大(+)或小(-)的档案。这个 SIZE 的规格有:
c: 代表 byte, k: 代表 1024bytes。所以,要找比 50KB
还要大的档案,就是『 -size +50k 』
-type TYPE :搜寻档案的类型为 TYPE 的,类型主要有:一般正规档案 (f),
装置档案 (b, c), 目录 (d), 连结档 (l), socket (s),
及 FIFO (p) 等属性。
-perm mode :搜寻档案属性『刚好等于』 mode 的档案,这个 mode 为类似 chmod
的属性值,举例来说, -rwsr-xr-x 的属性为 4755 !
-perm -mode :搜寻档案属性『必须要全部囊括 mode 的属性』的档案,举例来说,
我们要搜寻 -rwxr–r– ,亦即 0744 的档案,使用 -perm -0744,
当一个档案的属性为 -rwsr-xr-x ,亦即 4755 时,也会被列出来,
因为 -rwsr-xr-x 的属性已经囊括了 -rwxr–r– 的属性了。
-perm +mode :搜寻档案属性『包含任一 mode 的属性』的档案,举例来说,我们搜寻
-rwxr-xr-x ,亦即 -perm +755 时,但一个档案属性为 -rw——-
也会被列出来,因为他有 -rw…. 的属性存在!
4. 额外可进行的动作:
-exec command :command 为其它指令,-exec 后面可再接额外的指令来处理搜寻到
的结果。
-print :将结果打印到屏幕上,这个动作是预设动作!

范例:
范例一:将过去系统上面 24 小时内有更动过内容 (mtime) 的档案列出
# find / -mtime 0
# 那个 0 是重点!0 代表目前的时间,所以,从现在开始到 24 小时前,
# 有变动过内容的档案都会被列出来!那如果是三天前的 24 小时内?
# find / -mtime 3 ,意思是说今天之前的 3*24 ~ 4*24 小时之间
# 有变动过的档案都被列出的意思!同时 -atime 与 -ctime 的用法相同。

范例二:寻找 /etc 底下的档案,如果档案日期比 /etc/passwd 新就列出
# find /etc -newer /etc/passwd
# -newer 用在分辨两个档案之间的新旧关系是很有用的!
范例三:搜寻 /home 底下属于 dmtsai 的档案
# find /home -user dmtsai
# 这个东西也很有用的~当我们要找出任何一个使用者在系统当中的所有档案时,
# 就可以利用这个指令将属于某个使用者的所有档案都找出来喔!
范例四:搜寻系统中不属于任何人的档案
# find / -nouser
# 透过这个指令,可以轻易的就找出那些不太正常的档案。
# 如果有找到不属于系统任何人的档案时,不要太紧张,
# 那有时候是正常的~尤其是您曾经以原始码自行编译软件时。
范例五:找出档名为 passwd 这个档案
# find / -name passwd
# 利用这个 -name 可以搜寻档名啊!
范例六:搜寻档案属性为 f (一般档案) 的档案
# find /home -type f
# 这个 -type 的属性也很有帮助喔!尤其是要找出那些怪异的档案,
# 例如 socket 与 FIFO 档案,可以用 find /var -type p 或 -type s 来找!
范例七:搜寻档案当中含有 SGID/SUID/SBIT 的属性
# find / -perm +7000
# 所谓的 7000 就是 —s–s–t ,那么只要含有 s 或 t 的就列出,
# 所以当然要使用 +7000 ,使用 -7000 表示要含有 —s–s–t 的所有三个权限,因此,就是 +7000 。
范例八:将上个范例找到的档案使用 ls -l 列出来
# find / -perm +7000 -exec ls -l {} \;
# 注意到,那个 -exec 后面的 ls -l 就是额外的指令,
# 而那个 {} 代表的是『由 find 找到的内容』的意思~所以, -exec ls -l {}
# 就是将前面找到的那些档案以 ls -l 列出长的数据!至于 \; 则是表示
# -exec 的指令到此为止的意思~意思是说,整个指令其实只有在
# -exec (里面就是指令下达) \;
# 也就是说,-exec 最后一定要以 \; 结束才行!这样了解了吗?!
范例九:找出系统中,大于 1MB 的档案
# find / -size +1000k
# 也可以使用 M 与 G 分别代表 MB 与 GB
### Linux `find` 命令使用指南 `find` 是一个强大的命令行工具,用于在目录层次结构中搜索文件和目录。它提供了丰富的选项来精确控制搜索行为,并支持基于多种条件(如名称、类型、大小、时间等)进行过滤。 #### 1. 基本语法 `find` 的基本语法如下: ```bash find [路径] [选项] [表达式] ``` - `[路径]`:指定搜索的起始目录。如果省略,则默认为当前目录。 - `[选项]`:控制搜索行为的参数。 - `[表达式]`:定义搜索条件的逻辑表达式。 #### 2. 常用选项 以下是一些常用的 `find` 命令选项及其功能: - **限制目录深度** 使用 `-maxdepth` 和 `-mindepth` 选项可以限制搜索的目录深度[^1]。例如,仅搜索当前目录而不进入子目录: ```bash find . -maxdepth 1 -name "*.txt" ``` - **跟随符号链接** 默认情况下,`find` 不会跟随符号链接。若需要强制跟随符号链接,可使用 `-L` 选项。但需注意,若遇到指向自身的符号链接,可能会导致死循环。 - **根据文件类型搜索** 可以通过 `-type` 选项指定文件类型[^1]。常见的文件类型包括: - `f`:普通文件 - `d`:目录 - `l`:符号链接 示例:查找所有普通文件: ```bash find /path/to/directory -type f ``` - **按名称搜索** 使用 `-name` 或 `-iname`(忽略大小写)选项可以根据文件名进行搜索。例如,查找扩展名为 `.log` 的文件: ```bash find /var -name "*.log" ``` - **按修改时间搜索** 可以使用 `-mtime`、`-atime` 和 `-ctime` 选项根据文件的时间戳进行搜索。例如,查找最近 7 天内修改过的文件: ```bash find /path/to/directory -mtime -7 ``` - **按大小搜索** 使用 `-size` 选项可以根据文件大小进行搜索。例如,查找大于 100MB 的文件: ```bash find /path/to/directory -size +100M ``` #### 3. 综合示例 以下是一些综合使用的示例: - 查找当前目录下所有普通文件并删除: ```bash find . -type f -exec rm -f {} \; ``` - 查找 `/home` 目录下所有空文件: ```bash find /home -type f -empty ``` - 查找 `/etc` 目录下所有最近 24 小时内访问过的配置文件: ```bash find /etc -type f -atime 0 ``` #### 4. 注意事项 - 使用 `-exec` 选项执行命令时,请确保命令的安全性,避免误删重要文件。 - 当搜索范围较大时,`find` 命令可能需要较长时间完成,建议结合 `-maxdepth` 限制搜索范围。 ```bash # 示例:查找当前目录下所有普通文件并打印其权限 find . -type f -exec ls -l {} \; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值