德·摩根定律
奧古斯都·德·摩根首先發現了在邏輯命題中存在著下面這些關系:
非(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.www58058.com/36556
要想學會find的高級使用,摩根定律是不可避免要去學習的概念,同時find命令也是筆試中常出現的問題,希望能多多練習,熟練運用。