原文:
http://www.cnblogs.com/serendipity/articles/2133385.html
http://linux.chinaunix.net/techdoc/develop/2007/08/21/965951.shtml
一、find 命令格式
1、find命令的一般形式為;
find pathname -options [-print -exec -ok ...]
2、find命令的參數;
pathname: find命令所尋找的目錄路徑。例如用.來表示目前的目錄,用/來表示系統根目錄。
-print: find命令將匹配的檔案輸出到標準輸出。
-exec: find命令對匹配的檔案執行該參數所給出的shell命令。相應命令的形式為'command' { } \;,注意{ }和\;之間的空格。
-ok: 和-exec的作用相同,只不過以一種更為安全的模式來執行該參數所給出的shell命令,在執行每一個命令之前,都會給出提示,讓使用者來確定是否執行。
3、find命令選項
-name
按照檔案名稱尋找檔案。
-perm
按照檔案許可權來尋找檔案。
-prune
使用這一選項可以使find命令不在當前指定的目錄中尋找,如果同時使用-depth選項,那麼-prune將被find命令忽略。
-user
按照檔案屬主來尋找檔案。
-group
按照檔案所屬的組來尋找檔案。
-mtime -n +n
按照檔案的更改時間來尋找檔案, - n表示檔案更改時間距現在n天以內,+ n表示檔案更改時間距現在n天以前。find命令還有-atime和-ctime 選項,但它們都和-m time選項。
-nogroup
尋找無有效所屬組的檔案,即該檔案所屬的組在/etc/groups中不存在。
-nouser
尋找無有效屬主的檔案,即該檔案的屬主在/etc/passwd中不存在。
-newer file1 ! file2
尋找更改時間比檔案file1新但比檔案file2舊的檔案。
-type
尋找某一類型的檔案,諸如:
b - 塊裝置檔案。
d - 目錄。
c - 字元裝置檔案。
p - 管道檔案。
l - 符號連結檔案。
f - 普通檔案。
-size n:[c] 尋找檔案長度為n塊的檔案,帶有c時表示檔案長度以位元組計。
-depth:在尋找檔案時,首先尋找目前的目錄中的檔案,然後再在其子目錄中尋找。
-fstype:尋找位於某一類型檔案系統中的檔案,這些檔案系統類型通常可以在設定檔/etc/fstab中找到,該設定檔中包含了本系統中有關檔案系統的資訊。
-mount:在尋找檔案時不跨越檔案系統mount點。
-follow:如果find命令遇到符號連結檔案,就跟蹤至連結所指向的檔案。
-cpio:對匹配的檔案使用cpio命令,將這些檔案備份到磁帶裝置中。
另外,下面三個的區別:
-amin n
尋找系統中最後N分鐘訪問的檔案
-atime n
尋找系統中最後n*24小時訪問的檔案
-cmin n
尋找系統中最後N分鐘被改變檔案狀態的檔案
-ctime n
尋找系統中最後n*24小時被改變檔案狀態的檔案
-mmin n
尋找系統中最後N分鐘被改變檔案資料的檔案
-mtime n
尋找系統中最後n*24小時被改變檔案資料的檔案
4、使用exec或ok來執行shell命令
使用find時,只要把想要的操作寫在一個檔案裡,就可以用exec來配合find尋找,很方便的
在有些作業系統中只允許-exec選項執行諸如l s或ls -l這樣的命令。大多數使用者使用這一選項是為了尋找舊檔案並刪除它們。建議在真正執行rm命令刪除檔案之前,最好先用ls命令看一下,確認它們是所要刪除的檔案。
exec選項後面跟隨著所要執行的命令或指令碼,然後是一對兒{ },一個空格和一個\,最後是一個分號。為了使用exec選項,必須要同時使用print選項。如果驗證一下find命令,會發現該命令只輸出從當前路徑起的相對路徑及檔案名稱。
例如:為了用ls -l命令列出所匹配到的檔案,可以把ls -l命令放在find命令的-exec選項中
# find . -type f -exec ls -l { } \;
-rw-r--r-- 1 root root 34928 2003-02-25 ./conf/httpd.conf
-rw-r--r-- 1 root root 12959 2003-02-25 ./conf/magic
-rw-r--r-- 1 root root 180 2003-02-25 ./conf.d/README
上面的例子中,find命令匹配到了目前的目錄下的所有普通檔案,並在-exec選項中使用ls -l命令將它們列出。
在/logs目錄中尋找更改時間在5日以前的檔案並刪除它們:
$ find logs -type f -mtime +5 -exec rm { } \;
記住:在shell中用任何方式刪除檔案之前,應當先查看相應的檔案,一定要小心!當使用諸如mv或rm命令時,可以使用-exec選項的安全模式。它將在對每個匹配到的檔案進行操作之前提示你。
在下面的例子中, find命令在目前的目錄中尋找所有檔案名稱以.LOG結尾、更改時間在5日以上的檔案,並刪除它們,只不過在刪除之前先給出提示。
$ find . -name "*.conf" -mtime +5 -ok rm { } \;
< rm ... ./conf/httpd.conf > ? n
按y鍵刪除檔案,按n鍵不刪除。
任何形式的命令都可以在-exec選項中使用。
在下面的例子中我們使用grep命令。find命令首先匹配所有檔案名稱為“ passwd*”的檔案,例如passwd、passwd.old、passwd.bak,然後執行grep命令看看在這些檔案中是否存在一個sam使用者。
# find /etc -name "passwd*" -exec grep "sam" { } \;
sam:x:501:501::/usr/sam:/bin/bash
二、find命令的例子;
1、尋找目前使用者主目錄下的所有檔案:
下面兩種方法都可以使用
$ find $HOME -print
$ find ~ -print
2、讓目前的目錄中檔案屬主具有讀、寫入權限,並且檔案所屬組的使用者和其他使用者具有讀許可權的檔案;
$ find . -type f -perm 644 -exec ls -l { } \;
3、為了尋找系統中所有檔案長度為0的普通檔案,並列出它們的完整路徑;
$ find / -type f -size 0 -exec ls -l { } \;
4、尋找/var/logs目錄中更改時間在7日以前的普通檔案,並在刪除之前詢問它們;
$ find /var/logs -type f -mtime +7 -ok rm { } \;
5、為了尋找系統中所有屬於root組的檔案;
$find . -group root -exec ls -l { } \;
-rw-r--r-- 1 root root 595 10月 31 01:09 ./fie1
6、find命令將刪除當目錄中訪問時間在7日以來、含有數字尾碼的admin.log檔案。
該命令只檢查三位元字,所以相應檔案的尾碼不要超過999。先建幾個admin.log*的檔案 ,才能使用下面這個命令
$ find . -name "admin.log[0-9][0-9][0-9]" -atime -7 -ok
rm { } \;
< rm ... ./admin.log001 > ? n
< rm ... ./admin.log002 > ? n
< rm ... ./admin.log042 > ? n
< rm ... ./admin.log942 > ? n
7、為了尋找當前檔案系統中的所有目錄並排序;
$ find . -type d | sort