Linux之查找命令find简介

查找命令find简介

 

 Linux使用过程中难免会遇到查找功能,类似于Windows中的搜索功能,如果想要找某个文件在什么地方,什么格式的文件等等。在Linux中我们可以使用findlocatewhichwhereis等命令。接下来我们就简单说一下如何使用这几个命令查找文件。

一、which

which命令的作用是,在PATH变量指定的路径中,搜索某个系统命令的位置,并且返回第一个搜索结果。也就是说,使用which命令,就可以看到某个系统命令是否存在,以及执行的到底是哪一个位置的命令。

实例:1.png

二、Whereis

whereis命令只能用于程序名的搜索,而且只搜索二进制文件(参数-b)、man说明文件(参数-m)和源代码文件(参数-s)。如果省略参数,则返回所有信息。2.png

三、Locate

locate命令其实是"find -name"的另一种写法,但是要比后者快得多,原因在于它不搜索具体目录,而是搜索一个数据库(/var/lib/mlocate/mlocate.db),这个数据库中含有本地所有文件信息。Linux系统自动创建这个数据库,并且每天自动更新一次,所以使用locate命令查不到最新变动过的文件。为了避免这种情况,可以在使用locate之前,先使用updatedb命令,手动更新数据库。

实例:3.png

因为Locate命令必须在数据库定时更新或者手动updatedb后才可以查找最近操作过的文件,且如果系统比较大则创建索引所需时间比较长,locate查找文件名时在路径中包含也会被查找出来,查找结果模糊,所以我们在此不再多说,重点说一下find的用法。

四、find(重点)

find是最常见和最强大的查找命令,你可以用它找到任何你想找的文件。根据文件的各种属性去找到相对应文件;支持实时查找,精准查找,精确匹配,缺点是速度较locate慢,但是功能强大,是我们日常最常使用的命令之一。

1find的基本用法

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

             查找路径:默认为当前目录

             查找条件:默认为指定路径下的所有文件

             处理动作:默认为显示至屏幕

2、查找条件:

      2.1 -name "文件名称" :支持使用globbing字符;

                    *:任意长度的任意字符

                    ?:任意单个字符

                    []:指定范围内的字符

                    [^]:指定范围外的字符

      2.2 -iname "文件名称" :查找时忽略大小写,

      2.3 -user username :根据文件的属主查找;

             例如:查找/var/目录属主为root且属组为mail的所有文件4.png

      2.4 -group grpname :根据文件的属组查找;find /home -user openstack –ls

      2.5 -nogroup 查找无有效所属组的文件,即该文件所属的组在/etc/groups中不存在

            -nouser 查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在。5.png

      2.6  组合条件查找:

                   与: -a

                   :  -o

                   非; -not  !取反

      例如:查找/home/目录下不属于rootbin的并且是链接类型的文件6.png

      2.7  -type 查找某一类型的文件,如:

                    b – 块设备文件

                    d – 目录

                    c – 字符设备文件

                    p – 管道文件

                    l – 符号链接文件

                    f – 普通文件

                    s – socket文件

      2.8  根据文件的大小查找:size [+ | -]# UNIT

             UNIT单元可以为:KMG

             find /var/log -size 2k      1<x<=2  的为2k

             #unit:  #-1 < x <= #  #表示查找的范围为小于#且大于#-1单位内大小的文件

           -#unit:  x<=#-1           -#表示的其实是#-1范围内的文件       如: -2k    1.1是不符合的,其实是x<=1k的文件

             +#unit: x>#               +#表示的是大于#号的文件          如:      +2k   2.1 2.4符合条件7.png

      2.9  根据时间戳查找:

             以天为单位:

             -[ atime |mtime |ctime ]    [+ | -]#

             +#:  x>= (#+1)            +#表示#+1天之前被访问过的文件

             -# x< #             -#表示小于#天之内的访问过的文件    例如: -2:最近一次访问时间为在两天之内

             #:  # <= x < #+1     #表示在##+1天之内访问过的文件

             以分钟为单位:同上

             -amin   -mmin   -cmin

             说明:Linux的文件有三个时间,分别是访问时间、修改时间、状态改动时间,分别对应的是atime(也就是access  time)、mtimemodify time)、ctimechange    time)。这  三个时间有所不同。

   atime:当文件的内容被访问的时候,比如使用命令cat,这时候访问时间会改变。

   mtime:当文件的内容被改变的时候,比如用vi编辑器编辑之后保存,这时候修改时间会被改变。

   ctime:当文件的属性或者权限被改变的时候,这时候状态改变时间会被改变。

   可以用stat  文件名来查看这三个时间。

   实例:查找/test目录下最近一周内其内容修改过的,且不属于rootbin的文件8.png

2.10  根据权限查找:-perm [+|-] mode

             mode mode 精确匹配

             +mode: 任何一类用户的权限,只要能包含对其指定任何一位权限即可,以属主为例;

             -mode: 每类用户指定的检查权限都匹配,为三类用户所有指定的检查权限都包含;9.png

2.11  处理动作:

             -print :默认处理动作,显示

             -ls :

             -exec command {} \;      -exec find命令对匹配的文件执行该参数所给出的其他linux命令,注意{}\;之间的空格;

             -ok – exec的作用相同,只不过和会人交互而已,OK执行前会向你确认是不是要执行。10.png

2.12  find :一次性查找所有符合条件的所有文件,并一同传递给-exec-ok后面的指定的命令;但是有些命令不能接受过长的参数;此时使用另一种方式;

                           find | xargs command

例如:当我们去删除比较多的文件是:比如本地目录下的/media/rehat/Packages中的rpm包时,如果执行find ./ -name “*.rpm” | rm –rf 时,将不执行任何操作;11.png

以上find等查找命令的一些使用操作,实际使用过程中find使用频率很高,遇到问题在与大家分享,如有不正之处,敬请指正!!!谢谢。

 

原创文章,作者:wxdz_2004(古雨秋),如若转载,请注明出处:http://www.178linux.com/4485

(1)
上一篇 2015-05-18 17:45
下一篇 2015-05-18 17:47

相关推荐

  • Linux文本处理工具grep

    文件查看工具:cat     将[文件]或标准输入组合输出到标准输出。               -A, –show-all       &nbs…

    Linux干货 2016-08-10
  • 关于绑定与不绑定CPU的对比

        此文严格意义上说,我没有很大的把握,其中关于CPU调度域的概念现在还有些混淆,但还是发出来,希望能做点铺路的贡献吧。    另外CPU调度域的原理我没办法自己写,能力尚浅, 只能将IBM知识库 和 另一位博主的文章摘录如下,并添加了些帮助理解的图片,希望能帮助到初学者。 …

    Linux干货 2016-05-03
  • zabbix表分区(适用于zabbix2.0.x,zabbix2.2.x和zabbix2.4.x)

    本文主要介绍了zabbix进行数据库表分区的方法:         在系统监控中,zabbix已经代替了nagios+cacti,zabbix以其良好的图形展示和高度自定义赢得了很多运维人员的喜爱。但是由于在工作中,zabbix跑的时间过长(我们公司跑了将近3年),web页面经常卡顿,监控…

    Linux干货 2015-10-27
  • N22-妙手-第七周博客作业第四题:RAID各级别的特性

    什么是RAID RAID的全称是Redundant Array of Independent Disks – 独立磁盘冗余阵列。基本思想是将多个相对便宜的硬盘组合成为一个硬盘阵列,使其在性能上达到或超过一块价格昂贵、容量巨大的硬盘。RAID通常被用在服务器上,使用完全相同的硬盘组成一个逻辑扇区,因此操作系统会把其当做一块硬盘。RAID分为不同的等…

    Linux干货 2016-09-27
  • shell编程、程序包管理及习题

    shell编程、程序包管理及习题 一、编程语句 1、while 循环 while CONDITION; do     循环体 done CONDITION :循环控制条件;进入循环之前,先做一次判 断;每一次循环之后会再次做判断;条件为“true” ,则执行 一次循环;直到条件测试状态为“false” 终止循环 因此:…

    Linux干货 2016-08-18
  • 上古神器vim

    概述:     在之前的篇章中,我们介绍了一些文本的处理工具,如grep、sed、cut、sort等,但是那些工具的侧重点都在于有了现成的文本之后,对现有的文本进行一定条件的加工处理后,满足我们进一步对数据的要求。但是目前为止,还没有接触一款专业用来编辑文本的工具,本篇就来介绍一下Linux系统上自带的专业用来文本编辑…

    Linux干货 2016-08-10

评论列表(2条)

  • stanley
    stanley 2015-05-18 17:46

    东郭的标签可以用极为专业来形容不过分

    • wxdz_2004(古雨秋)
      wxdz_2004(古雨秋) 2015-05-18 21:41

      @stanley是哪篇文章的标签?