文件查找命令find详解

文件的查找命令 find 用法

功能:实时查找工具,通过遍历指定路径完成文件查找

工作特点:

•  查找速度略慢
•  精确查找
•  实时查找
•  可能只搜索用户具备读取和执行权限的目录

语法:

  find [OPTION]… [查找路径] [查找条件] [处理动作]

查找路径:指定具体目标路径;默认为当前目录
查找条件:指定的查找标准,可以文件名、大小、类型、权限等标准进行;默认为找出指定路径下的所有文件
处理动作:对符合条件的文件做操作,默认输出至屏幕

1.find 查找条件

1.1根据文件名和inode查找:

  • -name "文件名称":支持使用glob

  • *, ?, [], [^]

  • -iname "文件名称":不区分字母大小写

  • -inum n  按inode号查找

  • -samefile name  相同inode号的文件

  • -links n  链接数为n的文件

  • -regex "PATTERN":以PATTERN匹配整个文件路径字符串,而不仅仅是文件名称

        find -name snow.png
      • 搜索名为snow.png的文件
        find -iname snow.png
      • 不分大小写地搜索名为snow.png、Snow.png、SNOW.PNG等等的文件
       find / -name “*.txt”  搜索后缀为.txt的文件
       find /var –name “*log*”

1.2根据属主、属组查找:

  • -user USERNAME:查找属主为指定用户(UID)的文件

  • -group GRPNAME: 查找属组为指定组(GID)的文件

  • -uid UserID:查找属主为指定的UID号的文件

  • -gid GroupID:查找属组为指定的GID号的文件

  • -nouser:查找没有属主的文件

  • -nogroup:查找没有属组的文件

       find -user gentoo  -group gentoo
       搜索被用户gentoo 以及组群gentoo所拥有的文件

1.3根据文件类型查找:

-type TYPE:

•  f: 普通文件
•  d: 目录文件
•  l: 符号链接文件
•  s:套接字文件
•  b: 块设备文件
•  c: 字符设备文件
•  p: 管道文件

组合条件:

与:-a
或:-o
非:-not, !

找出/tmp目录下,属主不是root,且文件名不以f开头的文件
    find /tmp \( -not -user root -a -not -name 'f*' \) -ls
    find /tmp -not \( -user root -o -name 'f*' \)  –ls

1.4根据文件大小来查找:

-size [+|-] #计算单位    

常用单位:b,c,w,k, M, G

  • #k 表示(#-1k,#k]

  • -#k 表示[0,#-1k]

  • +#k 表示(#k,+∞)

1.5根据时间戳:

以“天”为单位;

  • -atime [+|-]#,

    • #: [#,#+1)

    • +#: [#+1,∞]

    • -#: [0,#)

  • -atime

  • -ctime

  • —mtime

以“分钟”为单位:

  • -amin

  • -cmin

  • -mmin

      访问时间(-atime/天,-amin/分钟):用户最近一次访问时间。 
      修改时间(-mtime/天,-mmin/分钟):文件最后一次修改时间。 
      变化时间(-ctime/天,-cmin/分钟):文件数据元(例如权限等)最后一次修改时间。

1.6根据权限查找:

-perm [/|-]MODE
MODE: 精确权限匹配

  • /MODE:任何一类(u,g,o)对象的权限中只要能一位匹配即可,或关系,+ 从centos7开始淘汰

  • -MODE:每一类对象都必须同时拥有指定权限,与关系

    •0 表示不关注

• find -perm 755 会匹配权限模式恰好是755的文件

• 只要当任意人有写权限时,find -perm +222就会匹配

• 只有当每个人都有写权限时,find -perm -222才会匹配

• 只有当其它人(other)有写权限时,find -perm -002才
会匹配

2.find 处理动作

  • -print:默认的处理动作,表示显示至屏幕;

  • -ls:类似于对查找到的文件执行“ls -l”命令

  • -delete:删除查找到的文件;

  • -fls file:查找到的所有文件的长格式信息保存至指定文件中

  • -ok COMMAND {} \: 对查找到的每个文件执行由COMMAND指定的命令;对于每个文件执行命令之前,都会交互式要求用户确认()

  • -exec COMMAND {} \:对查找到的每个文件执行由COMMAND指定的命令,没有确认

注意:

find传递查找到的文件至后面指定的命令时,查找到所有符合条件的文件一次性传递给后面的命令
有些命令不能接受过多参数,此时命令执行可能会失败,下面方式可规避此问题
find | xargs COMMAND

操作练习

1、查找/var目录下属主为root,且属组为mail的所有文件

[root@localhost ~]# find /var -user root -group mail
/var/spool/mail
/var/spool/mail/root

2、查找/var目录下不属于root、lp、gdm的所有文件

 #find /var \( -not -user root -a -not -user lp -a -not -user gdm \)  -ls

3、查找/var目录下最近一周内其内容修改过,同时属主不为root,也不是postfix的文件

# find /var \( -mtime -7 -a -not -user root -a -not -user postfix \) -ls

4、查找当前系统上没有属主或属组,且最近一个周内曾被访问过的文件

#find / \( -nouser -nogroup -atime -7 \) -ls

5、查找/etc目录下大于1M且类型为普通文件的所有文件

[root@localhost ~]# find /etc -size +1M -type f

6、查找/etc目录下所有用户都没有写权限的文件

# find /etc/ -not -perm /222 -ls

7、查找/etc目录下至少有一类用户没有执行权限的文件

# find /etc/ -not -perm -111 -ls

8、查找/etc/init.d目录下,所有用户都有执行权限,且其它用户有写权限的文件

# find /etc/init.d -perm -113

原创文章,作者:N24_yezi,如若转载,请注明出处:http://www.178linux.com/58192

(1)
N24_yeziN24_yezi
上一篇 2016-11-07 10:57
下一篇 2016-11-07 12:21

相关推荐

  • 为大家准备了几道简单的小题,不知道看过这篇文章后能否做出来?(考验你能力的时候到了,接招吧。。。) 1、将0-9分别替代成a-j 2、将/etc/issue文件中的内容转换为大写后保存至/tmp/issue.out文件中 3、计算1+2+3+..+99+100的值 4、处理字符串“xt.,l 1 jr#!$mn2 c*/fe 3 uz 4”,只保留其中的数字…

    2017-07-22
  • 运筹帷幄之中,决胜与千里之外!

           运筹帷幄之中,决胜与千里之外,决定改变一生。        自从2016年年后学校要求产参加毕业实习,但对linux一窍不通的我,阴差阳错的被一家网络公司给录取了。        安排在一家企业做驻场运维工程师,刚去驻场的时候并没有给我分配相应的工作只是给了一些关于数据库,网络,和系统的一些资料,要求进行自学。我想了想,就决定选择了系统进行了解…

    2018-03-26
  • 马哥教育网络班22期+第六周课程练习

    vim编辑器的使用总结    vim编辑器是模式化的全屏文本编辑器,有三种基本模式:        编辑模式        输入模式   &…

    Linux干货 2016-10-24
  • 【社招】【小米-北京】大数据运维工程师

    【社招】【小米-北京】大数据运维工程师 【工作地点】北京市海淀区安宁庄东路72号科利源大厦 【薪酬福利】15k-30k  期权奖励、六险一金、水果花茶、班车、健身房、食堂 【投递方式】邮件主题“岗位+姓名”发送至lipengcheng3@xiaomi.com   工作职责: 1、负责大数据平台相关系统的运维保障,包括:Hadoo…

    Linux干货 2017-07-28
  • Homework Week-4 grep用法

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 cp -r /etc/skel /home/tuser1 chmod  -R g=,o= /home/tuser1 2、编辑/etc/group文件,添加…

    Linux干货 2016-09-06
  • 链接分析算法之:主题敏感PageRank

      前面的讨论提到。PageRank忽略了主题相关性,导致结果的相关性和主题性降低,对于不同的用户,甚至有很大的差别。例如,当搜索“苹果”时,一个数码爱好者可能是想要看 iphone 的信息,一个果农可能是想看苹果的价格走势和种植技巧,而一个小朋友可能在找苹果的简笔画。理想情况下,应该为每个用户维护一套专用向量,但面对海量用户这种方法显然不可行。所…

    Linux干货 2016-02-17