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)
wxdz_2004(古雨秋)wxdz_2004(古雨秋)
上一篇 2015-05-18
下一篇 2015-05-18

相关推荐

  • Linux用户、组和权限管理详解

    用户管理简要说明:     1.越是对服务器安全性要求高的服务器,越需要建立合理的用户权限等级制度和服务器操作规范。     2.在Linux中主要是通过用户配置文件来查看和修改用户信息。 初始组和附加组     初始组:就是指用户一登录就立刻拥有这个用户组的相关权限,每个用户的…

    Linux干货 2016-08-05
  • BIND(Berkeley Internet Name Domain) is an implementation of the DNS(Domain Name System) (Blob 12)

    正向解析区域、反向解析区域;主/从;子域;基本安全控制;

    2017-11-29
  • 七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

    格式说明: 操作 概念 命令 说明及举例 七.cat、cut、less、head、tail、wc、sort、uniq、grep cat cat -A a.txt 查看隐藏内容 cat -n a.txt 显示行号 cat -s a.txt 压缩空行,把多行空行压缩为一行 …

    Linux干货 2016-08-24
  • iptables

    iptables简介 netfilter/iptables(简称为iptables)组成Linux平台下的包过滤防火墙,与大多数的Linux软件一样,这个包过滤防火墙是免费的,它可以代替昂贵的商业防火墙解决方案,完成封包过滤、封包重定向和网络地址转换(NAT)等功能。 iptables基础 规则(rules)其实就是网络管理员预定义的条件,规则一般的定义为“…

    2017-05-02
  • Linux第三周学习博客作业

    对第三周学习的内容进行总结

    Linux干货 2017-12-17
  • 2016-08-12作业

    1、查找/var 目录下属主为root ,且属组为mail 的所有文件 [root@localhost bin]# find /var -user root -group mail /var/spool/mail /var/spool/mail/root   2、查找/var 目录下不属于root 、lp 、gdm 的所有文件 find /var …

    Linux干货 2016-08-15

评论列表(2条)

  • stanley
    stanley 2015-05-18 17:46

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

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

      @stanley是哪篇文章的标签?