文本查找之find组合拳

find命令不仅能帮助我们在数目众多的文件中快速找到满足条件的文本,我们还能通过find处理动作对查找到的文件进行进一步的处理。

一、find的特点:

              遍历查找,因此查找速度略慢

              精确查找

              实时查找

二、find用法:

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

查找路径:指定具体目标路径;默认为当前目录

查找条件:指定的查找标准,可以文件名、大小、类型、权限等标准进行

处理动作:对符合条件的文件做操作,默认输出至屏幕

       三、find查找条件:

1、根据文件名查找:

                     -name “文件名”: 文件支持glob通配符

                     -iname “文件名”: 查找时忽略文件名大小写

                     -inum  “文件inode号”: 根据文件inode号码查找

                     -links “链接数” :查找具有指定连接数的文件

                     -regex “pattern” :查找匹配”pattern”的文件,支持正则表达式

例(1)、查找当前目录下以sum开头的文件

blob.png

              2、根据属主、属组查找

                     -user username : 查找属主为指定用户的文件

                     -uid userid: 查找uid为指定id的文件

                     -group groupname: 查找属组为指定组的文件

                     -gid groupid: 查找gid为指定gid的文件

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

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

例(2)、查找系统中属主为hadoop的文件

blob.png

              3、根据文件类型查找:

                     -type filetype:

                          f:  普通文件

d:  目录文件

l:  符号链接文件

s : 套接字文件

b:  块设备文件

c:  字符设备文件

p:  管道文件

例(3)、 查找/etc/目录下的连接文件

blob.png

             4、组合条件:如果要查找满足不止一个特定条件的文件,就需要将这些条件组合起来。条件的组合有以下形式:

                  与:-a

或:-o

非:-not, !

              同时,组合条件遵循德摩根定律:

                     (非A) 且 (非B ) = 非(A 或 B)  !A -a !B = !(A -o B)

                     (非A) 或 (非B ) = 非(A 且 B)  !A -o !B = !(A -a B)

   例(4)、找出/tmp 目录下,属主不是root ,文件名不是以p开头的文件 ,用德摩根定律实现两种查找方式。

第一种:

blob.png

第二种:

 blob.png

5、根据文件大小来查找

                     -size  [+|-]nunit:

                            常用的单位有k、M、G

                     -size 6k: 查找的文件大小等于6k的文件,它的范围为(5K, 6k]

                     -size -6k:查找文件大小小于6k的文件,它的范围为[0,5k]

                     -size +6K:查找文件大小大于6k的文件,它的范围为(6,∞),不包含6k。

blob.png

6、根据时间戳查找

              以“天”为单位;

-atime  [+|-]n,

n: [n,n+1):比如查找第7天被访问过的文件,-atime 7查找范围为[7,8)

+n: [n+1, ∞ ]:查找7天前被访问过的文件,-atime +7查找范围为[8, ∞)

-n: [0,n):查找7天之内被访问过的文件,-atime -7查找范围为[0,7),0表示现在

-mtime

-ctime

以“分钟”为单位:

-amin

-mmin

-cmin

blob.png

7、根据权限查找

              -perm [/|-]mode:

                     mode  :  精确权限匹配

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

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

                     0表示不关注

       例:匹配所有用户只要写权限的文件,find  -perm  222

              匹配任何一类用户有写权限的文件,find  -perm  +222

              匹配所有用户都要写权限的文件,find  -perm  -222

              匹配其他用户有写权限的文件,find  -perm  -002

    四、处理动作

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

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

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

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

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

           -exec  COMMAND  {}  \;  对查找到的每个文件执行由COMMAND指定的命令

              {}:  用于引用查找到的文件名称自身

注:find 传递查找到的文件至后面指定的命令时,查找到所有符合条件的文件一次性传递给后面的命令。

    有些命令不能接受过多参数,此时命令执行可能会失败,下面方式可规避此问题

find  |  xargs  COMMAND

五、示例

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

find /var -user root -a -group mail

blob.png

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

find /var ! \( -user root -o -user lp -o -user gdm \) -ls

blob.png

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

find /var -mtime -7 -a ! \( -user root -o -user postfix \) | xargs  stat

blob.png

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

find / \( -nouser -o -nogroup \) -a -atime -7 -ls

blob.png

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

find /etc/ -size +1M  -ls

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

find /etc ! -perm +222 -ls

blob.png

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

find /etc/ ! -perm -111 -ls

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

find /etc/init.d/ -perm -111 -a -perm -002

原创文章,作者:M20-1钟明波,如若转载,请注明出处:http://www.178linux.com/36091

(0)
M20-1钟明波M20-1钟明波
上一篇 2016-08-15
下一篇 2016-08-15

相关推荐

  • 8.9作业

    删除/etc/grub2.conf文件中所有以空白开头的行,行首的空白字符 [root@English6 ~]# sed "s@^[[:space:]]\+@@" /etc/grub.conf  # grub.conf generated by an…

    Linux干货 2016-08-11
  • shell编写的linux命令练习工具

    linux常用命令加选项,有成百上个,仅仅靠背诵忘记得太快,所以写了此脚本,便于对linux命令的练习,希望能帮助到大家。 运行脚本效果如下: 上边两图一个是运行脚本时的截图,另一个为题库的格式(@做分隔符,所以如果题目中有@一定要替换掉) 下面附上源码 #!/bin/bash#版本号:1.0 #作者:Mr.L #WX:504498722FILE=/root…

    2017-03-19
  • 第二十六天 iptables 初识

      Iptables是位于用户空间,是linux系统上的防火墙管理配置规则的工具,主要用于添加、删除、管理netfilter的规则,   Netfilter是位于内核中真正的防火墙,由5个钩子组成,也叫五个规则链。 Netfilter的作用:起到过滤封包,转换与映射IP地址和端口,拆分和修改封包内容,追踪封包等功能 Iptabl…

    Linux干货 2016-07-02
  • 压缩、解压缩及归档工具

    压缩、解压缩及归档工具 一、杂项知识整理 1、find -iname 忽略大小写;     -inum 查找指定inode号的文件;  find 在有条件判断的时候,如果不加括号,最后的命令会被当成以为第二个条件之后的:例 [root@localhost shelltest]# find&…

    Linux干货 2016-08-18
  • Linux自动备份脚本

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://nolinux.blog.51cto.com/4824967/1541163        今天网上一个朋友问了我一个shell的题目,让我帮他做下。下面是题目以及解题思路。 题目:…

    Linux干货 2016-08-15
  • Linux文件管理类命令相关

    Linux文件管理类命令相关 1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 1)、查看文件命令: (1)ls命令: list,列出目录下的内容 语法: ls [OPTION]… [FILE]… 常用选项: -a: 显示所有文件,包括隐藏文件; -A:显示除.和..之外的所有文件; -l: –…

    Linux干货 2016-09-24

评论列表(2条)

  • 马哥教育
    马哥教育 2016-08-19 14:26

    find命令是笔试中常见的考点,同时find的处理动作也是很重要的,希望课后能多加练习,熟练掌握。