shell: find命令的使用方法

來源:互聯網
上載者:User

原文:

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
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.