在Linux系统中,我们经常需要在系统中根据文件的权限、文件属性、文件长度、文件类型等特征进行查找,常使用到的搜索命令是find
下面将详细介绍find命令的用法
一、find命令的一般形式:
find SearchPath -options SearchExpression [-print -exec -ok]
1、参数说明
SearchPath :find的查找路径,也就是在哪个路径下进行搜索,如.表示当前路;/表示根目录
SearchExpression :查找表达式
-print :find命令将匹配的文件输出到标准输出 (默认自动添加)
-exec :find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为'command' {} \;,注意{ }和\;之间的空格。
-ok :与exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,
在执行每一个命令之前,都会给出提示,让用户来确定是否执行。
2、例子
find . -print 输出当前目录下所有的子文件
find . -name a.sh -exec ls -l {} \; 在当前目录及子目录下搜索名为a.sh的文件,并执行ls -l命令
find . -name a.sh -ok ls -l {} \; 在当前目录及子目录下搜索名为a.sh的问,并将其删除
二、-options
1、-name 按照文件名查找文件
find . -name "*.sh" 在当前目录及子目录下查找扩展名为sh的文件
2、-perm 按照文件权限来查找文件
find . -perm 750 在当前目录及子目录下查找权限位为750的文件(精确)
find . -perm -111 在当前目录及目录下查找,只要所有用户均具有执行权限的文件(模糊)
3、-prune 使用这一选项可以使find命令不在当前指定的目录中查找,如果同时使用了-depth 选项,那么-prune选项将被find命令忽略。
4、-user 按照文件属主来查找文件。
find . -user imapuser 在当前目录及子目录下查看用户为imapuser的文件
5、-nouser 查找属主帐号被删除的文件,即该文件的属主在/etc/passwd中不存在,查找时不用给出属主帐号,系统会自动查找
find / -nouser 在根目录下搜索属主在/etc/passwd的不存在的文件
6、-group 按照文件所属的组来查找文件。
find . -group root 在当前目录及子目录下查看用户组为imapgroup的文件
7、-nogroup 查找属组帐号被删除的文件,即该文件所属的组在/etc/groups中不存在。
find / -nogroup 在根目录下搜索属组在/etc/group中不存在的文件
8、-mtime -n +n 按照文件的更改时间来查找文件,
- n 表示文件更改时间距现在n天以内,
+ n 表示文件更改时间距现在n天以前
find命令还有-atime和-ctime选项,但它们都和-mtime选项相似, 所以我们在这里只介绍-mtime选项。
find / -mtime -3 在根目录下查看3天之内修改过的文件
find / -ctime +3 在根目录下查看3天之内创建的文件
9、-newer file1 ! file2 查找更改时间比文件file1新但比文件file2旧的文件。
find . -newer a.sh ! -newer c.sh 在当前目录下查看文件的的更改时间介于a.sh、b.sh更改时间之间的文件
10、 -type 查找某一类型的文件,诸如:
b - 块设备文件。
d - 目录。
c - 字符设备文件。
p - 管道文件。
l - 符号链接文件。
f - 普通文件。
find / -type f 查找根目录下所有的普通文件
11、 -size n[c] 查找文件长度为n块的文件,带有c时表示文件长度以字节计。
find . -size +1000000c -print 当前目录下查找文件长度大于1 M字节的文件
find . -size 100c -print 当前目录下查找文件长度等于100字节的文件
find . -size +10 -print 当前目录下查找长度超过1 0块的文件(一块等于5 1 2字节)