find用法及德·摩根定律

德·摩根定律

  奥古斯都·德·摩根首先发现了在逻辑命题中存在着下面这些关系:

     非(P且Q)=非P或非Q

     非(P或Q)=非P且非Q

上述逻辑命题可以解释为:

   not ( P and Q)=not P or not Q

   not ( P or Q)=not P and not Q

 上述这些就是德·摩根定律的意思,我想说一下我对德·摩根定律的理解。因为“and”和"or"都在括号里,而"not"在括号外面,当"not“对括号里的值取反时,连"and”和"or“也一同取反,所以上述定律在我看来是这样子的:

  not ( P and Q)=(not P) (not and) (not Q)

而(not P)(not and)(not Q)=not P or not Q

所以:

   not ( P and Q)=not P or not Q

也就是说not不光是对P和Q取反,同时也对 and和or也取反。

     

解释完德·摩根定律了,接下来该说说find命令的用法了。

===================================================================================================================================

find命令的用法:

   find命令是一种实时查找工具,通过遍历指定路径完成文件查找

      特点:

       1、查找速度慢

       2、精确查找

       3、实时查找

       4、只搜索当前用户具备读取和执行权限的目录

       5、可以对搜索到的文件做处理

find命令的语法:

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

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

     查找条件:指定查找条件,可以是文件名、大小、类型、权限等标准进行;默认为找出指定路径下的所有文件

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

查找条件:

     根据文件名和inode查找:

     -name "文件名称":支持使用glob如:*,?,[],[^]

     -iname "文件名称":不区分字母大小写

     -inum n 按inode号查找

     -samefile name 相同inode号的文件

     -links n 链接数为n的文件

     -regex "PATTERN":以PATTERN匹配整个文件路径字符串,而不仅仅是文件名称

根据属主、属组查找:

    -user USERNAME:查找属主为指定用户(uid)的文件

    -group GRPNAME:查找数组为指定组(GID)的文件

    -uid UserID:查找属主为指定的UID号的文件

    -gid GroupID:查找属组为指定的GID号的文件

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

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

根据文件类型查找:   

     -type TYPE:

     f:普通文件

     d:目录文件

     l:符号链接文件

     s:套接字文件

     b:块设备文件

     c:字符设备文件

     p:管道文件

组合条件:

    与:-a

    或:-o

   非:-not,!

根据文件大小来查找:

      -size[+|-] 常用单位:k,M,G

根据时间戳:

     以“天”为单位

        -atime

        -mtime

        -ctime

     以“分钟”为单位;

        -amin

        -mmin

        -cmin   

根据权限查找:

       -perm [/|-]MODE

          MODE:精确权限匹配

          /MODE:任何一类权限中只要有以为匹配即可

          -MOD:每一类对象都必须同时拥有指定权限,  

处理动作:

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

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

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

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

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

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

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

注意:find传递查找到的文件至后面指定的命令时,查找到所有符合条件的文件一次性传递给后面的命令,而有些命令不能接受过多参数,此时命令会执行失败,使用下面命令可规避此问题:

        find | xargs COMMAND

练习题:

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

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

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

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

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

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

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

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

答案:

  1、 

[root@localhost ~]# find /var \( -user root -group mail \) -ls                          

393220    4 drwxrwxr-x   2 root     mail         4096 Aug 15 20:38 /var/spool/mail      

[root@localhost ~]#  

2、

[root@localhost ~]# find /var -not \( -user root -o -user lp -o -user gdm \) -ls

3、

[root@localhost ~]# find /var -mtime -7 -not -user root -not -user postfix

4、

[root@localhost ~]# find / -nouser -nogroup -atime -7

5、

[root@localhost ~]# find /etc -size +1M -type f

6、

find /etc -not -perm +111

7、

find /etc -not -perm -111

8、

find /etc/init.d -perm -113 

原创文章,作者:因为有你,如若转载,请注明出处:http://www.178linux.com/36556

(0)
因为有你因为有你
上一篇 2016-08-18
下一篇 2016-08-18

相关推荐

  • corosync + pacemaker搭建高可用http

    一、实验图:    二、实验环境准备:  1)时间同步(172.16.2.15是时间服务器) [root@web1 ~]# crontab  -e   */5 * * * * /usr/sbin/ntpdate&nbsp…

    Linux干货 2015-06-30
  • N26-肉肉-第一周作业

    1.描述计算机的组成及其功能CPU:运算器、控制器、寄存器、缓存存储器:内存,RAM(Random Access Memory)    IO:输入输出设备2.按系列罗列linux的发行版本,并描述不同发行版本之间的联系与区别。发行版有数百种之多,著名的主流发行版有3种Debian,Slackware,RedHatDebian:使…

    Linux干货 2017-01-03
  • Trap命令简介

     Trap命令简介     一、基本概念  trap是一个shell内建命令,它用来在脚本中指定信号如何处理。比如,按Ctrl+C会使脚本终止执行,实际上系统发送了SIGINT信号给脚本进程,SIGINT信号的默认处理方式就是退出程序。如果要在Ctrl +C不退出程序,那么就得使用trap命令来指定一下SIGINT的处…

    Linux干货 2015-05-11
  • DNS服务基础

    DNS服务:是一种工作在应用层的特定应用,也是.c/s架构模式的,DNS的是一种应用层协议,他的端口是UPD协议的53号端口,()根据应用场景不同也会用到tcp协议)这就意味着DNS是默认通过UDP协议进行通信的 我们访问任何一个网站都是通过主机名的方式进行访问的;例如www.baidu.com,这是个主机名.称之为FQDN(完全限定域名) 常见的顶级域中的…

    Linux干货 2016-11-07
  • 数据结构- 串的模式匹配算法:BF和 KMP算法

    Brute-Force算法的思想 1.BF(Brute-Force)算法   Brute-Force算法的基本思想是: 1) 从目标串s 的第一个字符起和模式串t的第一个字符进行比较,若相等,则继续逐个比较后续字符,否则从串s 的第二个字符起再重新和串t进行比较。 2) 依此类推,直至串t 中的每个字符依次和串s的一个连续的字符序列相等,则称模式匹…

    Linux干货 2015-04-07

评论列表(1条)

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

    要想学会find的高级使用,摩根定律是不可避免要去学习的概念,同时find命令也是笔试中常出现的问题,希望能多多练习,熟练运用。