Linux文件查找工具之find(详解)

find详解正则表达式

一.find命令是什么?ide

     实时查找工具,遍历指定目录中的全部文件完成查找。工具

二.find的工做特性:oop

实时查找ui

精确查找、支持众多查找标准spa

查找速度略慢blog

三.find的用法:hadoop

find [OPTIONS][查找路径][查找条件][处理动做]get

 (1)查找路径:指定具体的搜索目标的起始路径;默认为当前目录;it

 (2)查找条件:指定的查找标准,可根据文件名、大小、类型、从属关系、权限等标准进行。

   根据文件名查找:

 -name ‘FILENAME’:对文件名进行精确匹配;

       支持支持glob风格的通配符:*, ?, [], [^]

       -iname ‘FILENAME’:文件名匹配时不区分大小写;

       -regex PATTERN: 基于正则表达式进行文件名匹配;

    根据属主查找:-user USERNAME 

    根据属组查找:-group 

    根据UID查找:-uid UID

    根据GID查找:-gid GID

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

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

    按文件类型查找:-type f :普通文件

                          d:目录文件

                          l:符号连接文件

                          b:块设备文件

                          c:字符设备文件

                          p:管道文件

                          s:套接字文件

    按文件大小查找:

             -size [+|-] #UNIT

               #UNIT:(#-1, #]

              -#UNIT:[0,#-1]

              +#UNIT:(#, oo)

          经常使用UNIT:k ,M ,G  

          例:find /etc -size 10k,查找/etc下大于9k小于等于10k的文件 ;

               find /etc -size -10k ,查找/etc下小于等于9k的文件 ;

               find /etc -size +10k ,查找/etc下大于10k的文件。


 

    组合条件:-a:且

          -o:或

        -not:非  

     !A -a !B =!(A -o B)

     !A -o !B =!(A -a B)

    根据文件的时间戳查找:

        以“天”为单位,以 24 小时为一个单位。

wKioL1bkFc_AdofQAAAV-QCVtdM271.png

   图中最右边为目前的时间,越往左表示越早以前的时间轴;

             3:表示3—4那一天的文件;

            -3:表示小于等于3天内的文件;

            +3:表示大于等于4天前的文件.

           以“天”为单位:

                  -atime  

                  -mtime

                  -ctime

           以“分钟”为单位:

                  -amin

                  -mmin

                  -cmin

                  -newer file :file为一个存在的文件,列出比file还要新的文件名。

    根据权限查找:

             -perm[/|-] mode 

                  mode:精确权限匹配

                 /mode: 任何一类用户(u,g,o,)的权限中的任何一位(r,w,x)符合条件即知足;9位权限之间存在“或”的关系。

                -mode:每一类用户(u,g,o)的权限中的每一位(r,w,x)同时符合条件即知足,9位权限之间存在“与”关系。

 

(3)处理动做:对符合查找条件的文件作出的操做,例如删除、输出等操做;默认输出至标准输出。

     -print:输出至标准输出;默认的动做;

     -ls:相似于对查找到的文件执行“ls -l”命令,输出文件的详细信息;

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

     -fls /PATH/TO/SOMEFILE:把查找到的全部文件的长格式信息保存至指定文件中;

    -ok COMMAND {} \;   :对查找到的每一个文件执行由COMMAND表示的命令;每次操做都由用户进行确认;

    -exec COMMAND {} \;  :对查找到的每一个文件执行由COMMAND表示的命令;

      注意:find传递查找到的文件路径至后面的命令时,是先查找出全部符合条件的文件路径,并一次性传递给后面的命令;可是有些命令不能接受过长的参数,此时命令执行会失败;以下命令模式可规避此问题:

     find | xargs COMMAND

4、练习操做

一、查找/var目录下属主为root,且属组为mail的全部文件或目录;

wKiom1bkGF6DSQJRAAAVCgS9_DI499.png

二、查找/usr目录下不属于root, bin或hadoop的全部文件或目录;用两种方法;

wKioL1bkGQ2B9UxzAAA0sPXh_yY884.png

三、查找/etc目录下最近一周内其内容修改过,且属主不是root用户也不是hadoop用户的文件或目录;

wKiom1bkGKjxmprQAAAeT9a2pW8441.png

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

wKiom1bkGOOiODEfAAB2WwCV7Pc857.png

五、查找/etc目录下大于1M且类型为普通文件的全部文件;

wKiom1bkGSnBTaMtAAAXmGWOsUY664.png

六、查找/etc目录下全部用户都没有写权限的文件;

wKioL1bkGdCCeCUXAABgojVx6hg692.png

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

 ~]#find /etc -not -perm -111 -type f -ls

wKiom1bkGXTTHtEjAABk1fVy81M704.png

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

wKiom1bkGe-DvtV9AAANmIWK9zE519.png

相关文章
相关标签/搜索