ubuntu find方法

來源:互聯網
上載者:User
linux 下的find 命令 小總結..謝謝大家賞光!

通用格式:find pathname -options [-print -exec -ok]
例子:
find / -name filename 再根目錄裡面搜尋檔案名稱為filename的檔案
find /etc -name *s*在目錄裡面搜尋帶有s的檔案
find /etc -name *S 在目錄裡面搜尋以s結尾的檔案
find /etc -name s*在目錄裡面搜尋以s開頭的檔案
find / -amin -10在系統中搜尋最後10分鐘訪問的檔案
find / -atime -2尋找在系統中最後48小時訪問的檔案
find / -empty 尋找在系統中為空白的檔案或者是檔案夾
find / -group groupname 尋找在系統中屬於groupname的檔案
find / -mmin -5尋找在系統中最後5分鐘修改過的檔案
find / -mtime -1尋找在系統中最後24小時修改過的檔案
find /-nouser尋找在系統中屬於費使用者的檔案
find / -user username 尋找在系統中屬於username的檔案
find / -ctime -1尋找在系統中最後24小時被改變狀態的檔案
find / -fstype type尋找在系統中檔案類型為?的檔案
find / -user user1name -or -user user2name尋找在系統中屬於user1name或著屬於user2name的檔案
find / -user user1name -and -user2name在系統中尋找既屬於user1name又屬於user2name使用者的檔案.

一、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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.