linux查找命令-find
Linux的终端上,没有windows的搜索那样好用的图形界面工具,但find命令确是很强大的。
比如按名字查找一个文件,可以用 find / -name targetfilename
。 唉,如果只知道名字,不知道地点,这样也不失为一个野蛮有效的方法。
按时间查找也有参数 -atime 访问时间 -ctime 改变状态的时间 -mtime修改的时间
。但要注意,这里的时间是以24小时为单位的。
查看man手册后使用,你会很迷惑: -mtime n
: Files data was last modified n*24 hours ago. 字面上的理解是最后一次修改发生在n个24小时以前的文件,但实际上
find ./ -mtime 0
:返回最近24小时内修改过的文件。
find ./ -mtime 1
: 返回的是前48~24小时修改过的文件。而不是48小时以内修改过的文件。
那怎么返回10天内修改过的文件?find还可以支持表达式关系运算,所以可以把最近几天的数据一天天的加起来:
find ./ -mtime 0 -o -mtime 1 -o -mtime 2
……虽然比较土,但也算是个方法了。
还有没有更好的方法,我也想知道。
另外, -mmin参数-cmin / - amin
也是类似的。
简单应用实例
查找最近30分钟修改的当前目录下的.php文件
find . -name '*.php' -mmin -30
查找最近24小时修改的当前目录下的.php文件
find . -name '*.php' -mtime 0
查找最近24小时修改的当前目录下的.php文件,并列出详细信息
find . -name '*.inc' -mtime 0 -ls
查找当前目录下,最近24-48小时修改过的常规文件。
find . -type f -mtime 1
查找当前目录下,最近1天前修改过的常规文件。
find . -type f -mtime +1
find path -option [ -print ] [ -exec -ok command ] {}
find命令的参数;
- pathname: find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录。
- -print: find命令将匹配的文件输出到标准输出。
- -exec: find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为’command’ { } \;,注意{ }和\;之间的空格。
- -ok: 和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。
-print 将查找到的文件输出到标准输出 -exec command {} \; —–将查到的文件执行command操作,{} 和 \;之间有空格 -ok 和-exec相同,只不过在操作前要询用户
例:find . -name .svn | xargs rm -rf
-
-name filename #查找名为filename的文件
-
-perm #按执行权限来查找
-
-user username #按文件属主来查找
-
-group groupname #按组来查找
-
-mtime -n +n #按文件更改时间来查找文件,-n指n天以内,+n指n天以前
-
-atime -n +n #按文件访问时间来查GIN: 0px”>
-
-ctime -n +n #按文件创建时间来查找文件,-n指n天以内,+n指n天以前
-
-nogroup #查无有效属组的文件,即文件的属组在/etc/groups中不存在
-
-nouser #查无有效属主的文件,即文件的属主在/etc/passwd中不存
-
-newer f1 !f2 找文件,-n指n天以内,+n指n天以前
-
-ctime -n +n #按文件创建时间来查找文件,-n指n天以内,+n指n天以前
-
-nogroup #查无有效属组的文件,即文件的属组在/etc/groups中不存在
-
-nouser #查无有效属主的文件,即文件的属主在/etc/passwd中不存
-
-newer f1 !f2 #查更改时间比f1新但比f2旧的文件
-
-type b/d/c/p/l/f #查是块设备、目录、字符设备、管道、符号链接、普通文件
-
-size n[c] #查长度为n块[或n字节]的文件
-
-depth #使查找在进入子目录前先行查找完本目录
-
-fstype #查更改时间比f1新但比f2旧的文件
-
-type b/d/c/p/l/f #查是块设备、目录、字符设备、管道、符号链接、普通文件
-
-size n[c] #查长度为n块[或n字节]的文件
-
-depth #使查找在进入子目录前先行查找完本目录
-
-fstype #查位于某一类型文件系统中的文件,这些文件系统类型通常可 在/etc/fstab中找到
-
-mount #查文件时不跨越文件系统mount点
-
-follow #如果遇到符号链接文件,就跟踪链接所指的文件
-
-cpio %; #查位于某一类型文件系统中的文件,这些文件系统类型通常可 在/etc/fstab中找到
-
-mount #查文件时不跨越文件系统mount点
-
-follow #如果遇到符号链接文件,就跟踪链接所指的文件
-
-cpio #对匹配的文件使用cpio命令,将他们备份到磁带设备中
-
-prune #忽略某个目录
使用案例
1 |
|
查当前目录下的所有普通文件
find . -type f -exec ls -l {} \;
-rw-r–r– 1 root root 34928 2003-02-25 ./conf/httpd.conf -rw-r–r– 1 root root 12959 2003-02-25 ./conf/magic -rw-r–r– 1 root root 180 2003-02-25 ./conf.d/README
查当前目录下的所有普通文件,并在- e x e c选项中使用ls -l命令将它们列出
在/ l o g s目录中查找更改时间在5日以前的文件并删除它们:
$ find logs -type f -mtime +5 -exec -ok rm {} \;
================================================= 查询当天修改过的文件 ` find ./ -mtime -1 -type f -exec ls -l {} \;`
=================================================
查询文件并询问是否要显示
find ./ -mtime -1 -type f -ok ls -l {} \;
=================================================
查询并交给awk去处理
who | awk ’{print $1"\t"$2}’
================================================= awk—grep—sed
df -k | awk ‘{print $1}’ | grep -v ’none’ | sed s"/\/dev\///g"
文件系统
sda2
sda1
df -k | awk ‘{print $1}’ | grep -v ’none’
文件系统
/dev/sda2
/dev/sda1
-
在/tmp中查找所有的*.h,并在这些文件中查找“SYSCALL_VECTOR”,最后打印出所有包含”SYSCALL_VECTOR”的文件名 A)
find /tmp -name "*.h" | xargs -n50 grep SYSCALL_VECTOR
B)grep SYSCALL_VECTOR /tmp/*.h | cut -d’:' -f1| uniq > filename
C)find /tmp -name "*.h" -exec grep "SYSCALL_VECTOR" {} \; -print
-
比如要查找磁盘中大于3M的文件:
find . -size +3000k -exec ls -ld {} ;
-
将find出来的东西拷到另一个地方
find *.c -exec cp ‘{}’ /tmp ‘;’
-
如果有特殊文件,可以用cpio,也可以用这样的语法:
find dir -name filename -print | cpio -pdv newdir
-
查找2004-11-30 16:36:37时更改过的文件
find ./ -name "*php" | ls -l –full-time $A 2>/dev/null | grep "2004-11-30 16:36:37"
####