find 小记

1:查找当前目录的文件

find . -maxdepth 1 -name "*sql"

 2:查找类型为文件的

find . -type f -name "*sql"

 3:查找大小4k的文件( +4k 大于4k  , -4k  小于4k)

find . -size 4k -name "*sql"

网上找到的

用法总结如下:
find pathname -options [-print -exec -ok]
pathname:查找路径
-option:主要选项如下:
-name:按照文档名称查找
-perm:按照文档权限查找
-prune:不在当前指定的路径查找。假如同时指定了-depth选项,则prune被忽略
-user:按照文档属主查找
-group:按照文档属组查找
-mtime -n +n:按照文档更改时间查找。-n 指距离现在时间n天以内;+n n天以外
-nogroup:查找无效属组文档
-nouser:查找无效属主文档
-newer file1 !file2:查找更改时间比file1新比file2旧的文档
-type:查找某一类型文档
      b:块设备文档
      d:目录
      c:字符设备文档
      P:管道文档
      l:符号链接文档
      f:普通文档
-size n[c]查找文档长度为n块的文档 有[c]表示文档长度以字节计
-depth:查找时,首先查找当前目录文档,然后再在其子目录查找
-fstype:查找位于某一类型文档系统中的文档,文档系统类型可在/etc/fstab中找到
-mount:查找文档不跨越文档系统mount点
-follow:如碰到链接文档,则跟踪至链接所指向文档
-cpio:对匹配的文档使用cpio命令,将文档备份到磁带设备中 
-print:将匹配的文档输出到标准输出
-exec:对匹配的文档执行所给的shell命令。形式为:command { } \;注意{ }和\;之间的空格
-ok:和-exec作用相同。只但是以一种更安全的模式执行该参数所给的shell命令。在执行每个命令之前,都会给出提示,让用户确定是否执行
Linux中find常见用法示例
·find  path  -option  [  -print ]  [ -exec  -ok  command ]  {} \;
#-print 将查找到的文档输出到标准输出
#-exec  command  {} \;     -----将查到的文档执行command操作,{} 和 \;之间有空格
#-ok 和-exec相同,只但是在操作前要询用户
====================================================
-name  filename             #查找名为filename的文档
-perm                       #按执行权限来查找
-user   username            #按文档属主来查找
-group groupname            #按组来查找
-mtime  -n +n               #按文档更改时间来查找文档,-n指n天以内,+n指n天以前
-atime   -n +n              #按文档访问时间来查GIN: 0px">-perm                        #按执行权限来查找
-user   username            #按文档属主来查找
-group groupname            #按组来查找
-mtime  -n +n               #按文档更改时间来查找文档,-n指n天以内,+n指n天以前
-atime   -n +n              #按文档访问时间来查找文档,-n指n天以内,+n指n天以前 
-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                      #忽略某个目录
====================================================
$find  ~  -name  "*.txt"  -print    #在$HOME中查.txt文档并显示
$find  .   -name  "*.txt"  -print
$find  .   -name  "[A-Z]*"  -pri26nbsp;   #对匹配的文档使用cpio命令,将他们备份到磁带设备中
-prune                              #忽略某个目录
=====================================================
$find  ~  -name  "*.txt"  -print    #在$HOME中查.txt文档并显示
$find  .   -name  "*.txt"  -print
$find  .   -name  "[A-Z]*"  -print  #查以大写字母开头的文档
$find  /etc  -name  "host*"  -print #查以host开头的文档
$find  .  -name  "[a-z][a-z][0--9][0--9].txt"   -print  #查以两个小写字母和两个数字开头的txt文档
$find .  -perm  755  -print
$find  .  -perm -007  -exec ls -l {} \;  #查任何用户都可读写执行的文档同-perm 777
$find  . -type d  -print
$find  .  !  -type  d  -print 
$find  .  -type l  -print
$find  .  -size  +1000000c  -print       #查长度大于1Mb的文档
$find  .  -size  100c        -print      # 查长度为100c的文档
$find  .  -size  +10  -print             #查长度超过期作废10块的文档(1块=512字节)
$cd /
$find  etc  home  apps   -depth  -print  | cpio  -ivcdC65536  -o  /dev/rmt0
$find  /etc -name "passwd*"  -exec grep  "cnscn"  {}  \;  #看是否存在cnscn用户
$find . -name "yao*"  | xargs file
$find  . -name "yao*"  |  xargs  echo   "" > /tmp/core.log
$find  . -name "yao*"  | xargs  chmod  o-w
======================================================
find  -name april*                      在当前目录下查找以april开始的文档
find  -name  april*  fprint file        在当前目录下查找以april开始的文档,并把结果输出到file中
find  -name ap* -o -name may*  查找以ap或may开头的文档
find  /mnt  -name tom.txt  -ftype vfat  在/mnt下查找名称为tom.txt且文档系统类型为vfat的文档
find  /mnt  -name t.txt ! -ftype vfat   在/mnt下查找名称为tom.txt且文档系统类型不为vfat的文档
find  /tmp  -name wa* -type l           在/tmp下查找名为wa开头且类型为符号链接的文档
find  /home  -mtime  -2                 在/home下查最近两天内改变过的文档
find /home   -atime -1                  查1天之内被存取过的文档
find /home -mmin   +60                  在/home下查60分钟前改变过的文档
find /home  -amin  +30                  查最近30分钟前被存取过的文档
find /home  -newer  tmp.txt             在/home下查更新时间比tmp.txt近的文档或目录
find /home  -anewer  tmp.txt            在/home下查存取时间比tmp.txt近的文档或目录
find  /home  -used  -2                  列出文档或目录被改变过之后,在2日内被存取过的文档或目录
find  /home  -user cnscn                列出/home目录内属于用户cnscn的文档或目录
find  /home  -uid  +501                 列出/home目录内用户的识别码大于501的文档或目录
find  /home  -group  cnscn              列出/home内组为cnscn的文档或目录
find  /home  -gid 501                   列出/home内组id为501的文档或目录
find  /home  -nouser                    列出/home内不属于本地用户的文档或目录
find  /home  -nogroup                   列出/home内不属于本地组的文档或目录
find  /home   -name tmp.txt   -maxdepth  4  列出/home内的tmp.txt 查时深度最多为3层
find  /home  -name tmp.txt  -mindepth  3  从第2层开始查
find  /home  -empty                     查找大小为0的文档或空目录
find  /home  -size  +512k               查大于512k的文档
find  /home  -size  -512k               查小于512k的文档
find  /home  -links  +2                 查硬连接数大于2的文档或目录
find  /home  -perm  0700                查权限为700的文档或目录
find  /tmp  -name tmp.txt  -exec cat {} \;
find  /tmp  -name  tmp.txt  -ok  rm {} \;
find   /  -amin   -10       # 查找在系统中最后10分钟访问的文档
find   /  -atime  -2         # 查找在系统中最后48小时访问的文档
find   /  -empty              # 查找在系统中为空的文档或文档夹
find   /  -group  cat        # 查找在系统中属于 groupcat的文档
find   /  -mmin  -5         # 查找在系统中最后5分钟里修改过的文档
find   /  -mtime  -1        #查找在系统中最后24小时里修改过的文档
find   /  -nouser             #查找在系统中属于作废用户的文档
find   /  -user   fred       #查找在系统中属于FRED这个用户的文档
查当前目录下的任何普通文档 
--------------------------------------------------------------------------------
# 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 {} \;
=================================================
查询当天修改过的文档
[root@book class]# find  ./  -mtime  -1  -type f  -exec  ls -l  {} \;
=================================================
查询文档并询问是否要显示
[root@book class]# find  ./  -mtime  -1  -type f  -ok  ls -l  {} \;  
? y
-rw-r--r--    1 cnscn    cnscn       13709  1月 12 12:22 ./classDB.inc.php
[root@book class]# find  ./  -mtime  -1  -type f  -ok  ls -l  {} \;  
? n
[root@book class]# 
=================================================
查询并交给awk去处理
[root@book class]# who  |  awk  '{print $1"\t"$2}'
cnscn   pts/0
=================================================
awk---grep---sed
[root@book class]# df  -k |  awk '{print $1}' |  grep  -v  'none' |  sed  s"/\/dev\///g"
文档系统
sda2
sda1
[root@book class]# df  -k |  awk '{print $1}' |  grep  -v  'none'
文档系统
/dev/sda2
/dev/sda1
1)在/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
2)find / -name filename -exec rm -rf {} \;
   find / -name filename -ok rm -rf {} \;
3)比如要查找磁盘中大于3M的文档:
find . -size +3000k -exec ls -ld {} ;
4)将find出来的东西拷到另一个地方
find *.c -exec cp '{}' /tmp ';'
假如有特别文档,能够用cpio,也能够用这样的语法:
find dir -name filename -print | cpio -pdv newdir
6)查找2004-11-30 16:36:37时更改过的文档
# A=`find ./ -name "*php"` |  ls -l --full-time $A 2>/dev/null | grep "2004-11-30 16:36:37"