find、xargs命令使用及方法详解

find是linux命令,它将档案系统内符合expression的档案列出来,你可以指要档案的名称、类别、时间、大小、权限等不同命令的组合,只有完全相符的才会被列出来。
find可以在当前目录下甚至整个文件系统来查找某些文件或目录;

注意:find命令是相当耗资源的不得以的时候不要find的,比如说根 / 目录;

功能说明:查找文件或目录
    find-->实时查找:速度慢、精确匹配

命令语法:
find [options] [查找路径] [查找条件] [处理动作]
    查找路径:默认为当前目录
    查找条件:默认为查找指定路径下的所有文件
    处理动作:默认为显示

下面就来一起看下find的用法吧:

1.查找条件:根据文件名称查找时是严格区分字母大小写的

  -name "文件名称": 支持使用globbing
        *  :重复0次或者任意多次前面字符
        ? :单个字符 
        [] :字符范围
        [^]:排除字符范围


应用实例:
 1).查看/etc目录下有多少passwd文件:
[root@xiaomazi ~]#
[root@xiaomazi ~]#  find /etc -name "passwd"
/etc/pam.d/passwd
/etc/passwd
[root@xiaomazi ~]#

 2).查看/etc目录下所有以passwd开头的文件:
[root@xiaomazi ~]#  find /etc -name "passwd*"
/etc/pam.d/passwd
/etc/passwd-
/etc/passwd
[root@xiaomazi ~]#

 3).查看/etc目录下所有以passwd结尾的文件:
[root@xiaomazi ~]#  find /etc -name "*passwd"
/etc/pam.d/passwd
/etc/passwd
/etc/security/opasswd
[root@xiaomazi ~]#

 

2.-iname "文件名称":查找时不区分字符大小写
应用举例:

 1).查找/etc下所有以passwd开头的文件(并不区分大小写):
[root@xiaomazi ~]# touch /etc/Passwd -->创建测试文件
[root@xiaomazi ~]# find /etc -iname "passwd*"
/etc/pam.d/passwd
/etc/passwd-
/etc/passwd
/etc/Passwd
[root@xiaomazi ~]# rm -rf /etc/Passwd
注意不要再/etc目录下随便创建文件吆.

 

3.  根据属主属组来查找:

      -user UserName: 根据属主查找
      -group GroupName: 根据属组查找


应用举例:
1).查找文件的属主是Hadoop用户的文件:
[root@xiaomazi ~]# su - hadoop
[hadoop@xiaomazi ~]$ cp/etc/fstab/tmp/-->注意以谁的身份复制文件,文件的属主属组就是谁的.
[hadoop@xiaomazi ~]$ ls-l /tmp/
total 28
-rw-r--r--  1 hadoop hadoop  921 Feb 26 18:14 fstab
[hadoop@xiaomazi ~]$
[root@xiaomazi ~]# find /tmp -user hadoop
/tmp/fstab
[root@xiaomazi ~]#

2).查找文件的属组是hadoop用户的文件:
[root@xiaomazi ~]# find /tmp -group hadoop
/tmp/fstab
[root@xiaomazi ~]#

 

4.根据UID/GID来查找:
    -uid UID
    -gid GID
  如果我将Fedora用户删除,没有加选项-r,就不会删除用户文件的;如果文件的属主属组不在了,会发生什么问题呢?但是,如果此前不确定用户名,也可以使用uid的;


应用举例:
 1).查找/tmp目录下uid是501的所有文件:
[root@xiaomazi ~]# useradd fedora -->创建用户
[root@xiaomazi ~]# su - fedora -->切换到fedora用户
[fedora@xiaomazi ~]$ cp/etc/inittab/tmp/-->以fedora用户来复制文件
[fedora@xiaomazi ~]$ ls-l /tmp/
total 28
-rw-r--r--  1 hadoop hadoop  921 Feb 26 18:14 fstab
-rw-r--r--  1 fedora fedora  884 Feb 26 18:22 inittab
[fedora@xiaomazi ~]$ exit
logout
[root@xiaomazi ~]# userdel fedora -->模拟删除用户
[root@xiaomazi ~]# ls -l /tmp/
total 28
-rw-r--r--  1 hadoop hadoop  921 Feb 26 18:14 fstab
-rw-r--r--  1    501    501  884 Feb 26 18:22 inittab  -->注意:现在属主属组属于501
[root@xiaomazi ~]# find /tmp -user fedroa -->这是找不到的啦!
find: `fedroa' is not the name of a known user
[root@xiaomazi ~]# find /tmp -uid 501 -->假设我们知道fedora的uid,就可以全局范围的查找fedora的文件了.
/tmp/inittab
[root@xiaomazi ~]#


5.根据-nouser、-nogroup: 查找没有属主、属组的文件;
  -nouser:查找没有属主的文件,即该文件的属主在/etc/passwd中不存在。
  -nogroup: 查找没有属组的文件,即该文件所属的组在/etc/group中不存在。


应用举例:
1).假如说现在就在系统上找没有属主的文件应该怎么样找呢?
[root@xiaomazi ~]# find /tmp -nouser
/tmp/inittab
[root@xiaomazi ~]#

 

6.组合条件:
    -a: 与,同时满足(可以不写的)
    -o: 或,表示一个满足就可以
    -not, !:非,取反

应用举例:

1).查找/tmp目录下没有属主或属主为hadoop的文件:

[root@xiaomazi ~]# find /tmp -nouser -o -user hadoop
/tmp/inittab
/tmp/fstab
[root@xiaomazi ~]#

2).查找/tmp目录下属主为hadoop,并且文件以.txt结尾的文件:
[hadoop@xiaomazi ~]$ whoami
hadoop -->当前用户
[hadoop@xiaomazi ~]$ cd /tmp/
[hadoop@xiaomazi tmp]$ touch word.doc hello.txt
[hadoop@xiaomazi tmp]$ ll -->新建文件以便测试.
total 28
-rw-r--r--  1hadoop hadoop  921Feb 2618:14fstab
-rw-rw-r--  1hadoop hadoop    0Feb 2618:58hello.txt
-rw-r--r--  1501501884Feb 2618:22inittab
-rw-rw-r--  1hadoop hadoop    0Feb 2618:58word.doc
root用户
[root@xiaomazi ~]# find /tmp -user hadoop -name "*.txt"
/tmp/hello.txt
[root@xiaomazi ~]#

3).查找/tmp目录下属主为hadoop,并且也不是以.txt结尾的文件:

[root@xiaomazi ~]# find /tmp -user hadoop -a -not -name "*.txt"
/tmp/fstab
/tmp/word.doc
[root@xiaomazi ~]#

4).查找/tmp目录下属主不是hadoop,并且也不是以.txt结尾的文件
  I.使用的是-a选项:
[root@xiaomazi tmp]# find /tmp -not -user hadoop -a -not -name "*.txt"
/tmp
/tmp/inittab
/tmp/.ICE-unix
[root@xiaomazi tmp]#

  II.使用的是-o选项:

[root@xiaomazi tmp]#
[root@xiaomazi tmp]# find /tmp -not \( -user hadoop -o -name "*.txt" \)
/tmp
/tmp/inittab
/tmp/.ICE-unix
[root@xiaomazi tmp]#

5).查找/tmp目录下属主不是hadoop,或者不是以.txt结尾的:
[root@xiaomazi tmp]# find /tmp -not -user hadoop -o -not -name "*.txt"
/tmp
/tmp/inittab
/tmp/fstab
/tmp/word.doc
/tmp/.ICE-unix
[root@xiaomazi tmp]#

 

6.根据文件类型查找:

    -type: 根据文件类型查找
        f: 普通文件
        d: 目录
        b: 块设备
        c: 字符设备
        l: 符号链接文件
        p: 命名管道
        s: 套接字


应用举例:
1).将/tmp目录下的目录显示出来:
[root@xiaomazi tmp]# find /tmp -type d
/tmp
/tmp/.ICE-unix
[root@xiaomazi tmp]#

2).查找/tmp目录下的普通文件显示出来:
[root@xiaomazi tmp]# find /tmp -type f
/tmp/inittab
/tmp/fstab
/tmp/word.doc
/tmp/hello.txt
[root@xiaomazi tmp]#

相关推荐