歡迎光臨
每天分享高質量文章

31個實用find命令的案例

來自:高階資料庫技術

主要來自網際網路,透過整理而成


一、主要內容

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

1. 用檔案名查詢檔案

2.用檔案名查詢檔案,忽略大小寫

3. 使用mindepthmaxdepth限定搜尋指定目錄的深度

4. find命令查詢到的檔案上執行命令

5. 相反匹配

6. 使用inode編號查詢檔案

7. 根據檔案許可權查詢檔案

8. 找到home目錄及子目錄下所有的空檔案(0位元組檔案)

9. 查詢5個最大的檔案

10. 查詢5個最小的檔案

11. 使用-type查詢指定檔案型別的檔案

12. 透過和其他檔案比較修改時間查詢檔案

13. 透過檔案大小查詢檔案

14. 給常用find操作取別名

15. find命令刪除大型打包檔案

16.找到在1個小時內被更改的檔案

17.找到1個小時內被訪問過的檔案

18.查詢一個小時內狀態被改變的檔案

19.搜尋僅僅限定於檔案,不顯示檔案夾

20.僅僅查詢非隱藏的檔案(不顯示隱藏檔案)

21.查詢檔案修改時間在某一檔案修改後的檔案

22.查詢檔案訪問時間在某一檔案的修改時間之後的檔案

23.查詢狀態改變時間在某個檔案修改時間之後的檔案:

24.find命令輸出上使用 ls -l,列舉出1小時內被編輯過的檔案的詳細資訊

25.僅僅在當前檔案系統中搜索

26.在同一個命令中使用多個{}

27. 使用多個{}實體

28.將錯誤重定向到/dev/nul

29.將檔案名中的空格換成下劃線

30.find結果中同時執行兩條命令

31、常用指令

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

 

二、find命令實用實體總結

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

一、基於name查詢檔案

# find . -name tecmint.txt

# find /home -name tecmint.txt

# find /home -iname tecmint.txt

# find / -type d -name Tecmint

# find . -type f -name tecmint.php

# find . -type f -name “*.php”

 

 

二、基於許可權查詢檔案

# find . -type f -perm 0777 -print

# find / -type f ! -perm 777

# find / -perm 2644

# find / -perm 1551

# find / -perm /u=s

# find / -perm /g+s

# find / -perm /u=r

# find / -perm /a=x

# find / -type f -perm 0777 -print -exec chmod 644 {};

# find / -type d -perm 777 -print -exec chmod 755 {};

# find . -type f -name “tecmint.txt” -execrm -f {} ;

# find . -type f -name “*.txt” -exec rm -f{} ;

# find . -type f -name “*.mp3” -exec rm -f{} ;

# find /tmp -type f -empty

# find /tmp -type d -empty

# find /tmp -type f -name “.*”

 

 

三、基於使用者和組查詢檔案

# find / -user root -name tecmint.txt

# find /home -user tecmint

# find /home -group developer

# find /home -user tecmint -iname “*.txt”

 

四、基於時間查詢檔案或目錄

# find / -mtime 50

# find / -atime 50

# find / -mtime +50 –mtime -100

# find / -cmin -60

# find / -mmin -60

# find / -amin -60

 

五、基於大小查詢檔案或目錄

# find / -size 50M

# find / -size +50M -size -100M

# find / -size +100M -exec rm -rf {} ;

# find / -type f -name *.mp3 -size +10M -exec rm {} ;

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

 

三、詳細資訊

除了在一個目錄結構下查詢檔案這種基本的操作,你還可以用find命令實現一些實用的操作,使你的命令列之旅更加簡易。本文將介紹31種無論是於新手還是老鳥都非常有用的Linux find命令。

首先,在你的home目錄下麵建立下麵的空檔案,來測試下麵的find命令示例。

 

# vimcreate_sample_files.sh

touchMybashProgram.sh

touch mycprogram.c

touch MyCProgram.c

touch Program.c

mkdir backup

cd backup

touchMybashProgram.sh

touch mycprogram.c

touch MyCProgram.c

touch Program.c

# chmod +xcreate_sample_files.sh

#./create_sample_files.sh

# ls -R

.:

backup                  MybashProgram.sh  MyCProgram.c

create_sample_files.sh  mycprogram.c      Program.c

./backup:

MybashProgram.sh  mycprogram.c MyCProgram.c  Program.c

 

1. 用檔案名查詢檔案

 

這是find命令的一個基本用法。下麵的例子展示了用MyCProgram.c作為查詢名在當前目錄及其子目錄中查詢檔案的方法。

 

# find -name”MyCProgram.c”

./backup/MyCProgram.c

./MyCProgram.c

 

2.用檔案名查詢檔案,忽略大小寫

 

這是find命令的一個基本用法。下麵的例子展示了用MyCProgram.c作為查詢名在當前目錄及其子目錄中查詢檔案的方法,忽略了大小寫。

 

# find -iname”MyCProgram.c”

./mycprogram.c

./backup/mycprogram.c

./backup/MyCProgram.c

./MyCProgram.c

 

3. 使用mindepthmaxdepth限定搜尋指定目錄的深度

 

root目錄及其子目錄下查詢passwd檔案。

 

# find / -namepasswd

./usr/share/doc/nss_ldap-253/pam.d/passwd

./usr/bin/passwd

./etc/pam.d/passwd

./etc/passwd

 

root目錄及其1層深的子目錄中查詢passwd. (例如root —level 1, and one sub-directory — level 2)

 

# find -maxdepth 2-name passwd

./etc/passwd

 

root目錄下及其最大兩層深度的子目錄中查詢passwd檔案. (例如 root — level 1, and two sub-directories — level 2 and 3 )

 

# find / -maxdepth 3-name passwd

./usr/bin/passwd

./etc/pam.d/passwd

./etc/passwd

 

在第二層子目錄和第四層子目錄之間查詢passwd檔案。

 

# find -mindepth 3-maxdepth 5 -name passwd

./usr/bin/passwd

./etc/pam.d/passwd

 

4. find命令查詢到的檔案上執行命令

 

下麵的例子展示了find命令來計算所有不區分大小寫的檔案名為“MyCProgram.c”的檔案的MD5驗證和。{}將會被當前檔案名取代。

 

find -iname”MyCProgram.c” -exec md5sum {} ;

d41d8cd98f00b204e9800998ecf8427e  ./mycprogram.c

d41d8cd98f00b204e9800998ecf8427e  ./backup/mycprogram.c

d41d8cd98f00b204e9800998ecf8427e  ./backup/MyCProgram.c

d41d8cd98f00b204e9800998ecf8427e  ./MyCProgram.c

 

5. 相反匹配

 

顯示所有的名字不是MyCProgram.c的檔案或者目錄。由於maxdepth1,所以只會顯示當前目錄下的檔案和目錄。

 

find -maxdepth 1-not -iname “MyCProgram.c”

.

./MybashProgram.sh

./create_sample_files.sh

./backup

./Program.c

 

6. 使用inode編號查詢檔案

 

任何一個檔案都有一個獨一無二的inode編號,藉此我們可以區分檔案。建立兩個名字相似的檔案,例如一個有空格結尾,一個沒有。

 

touch”test-file-name”

# touch”test-file-name “

[Note: There is aspace at the end]

# ls -1 test*

test-file-name

test-file-name

 

ls的輸出不能區分哪個檔案有空格結尾。使用選項-i,可以看到檔案的inode編號,藉此可以區分這兩個檔案。

 

ls -i1 test*

16187429test-file-name

16187430test-file-name

 

你可以如下麵所示在find命令中指定inode編號。在此,find命令用inode編號重新命名了一個檔案。

 

find -inum 16187430-exec mv {} new-test-file-name ;

 

 # ls -i1 *test*

16187430new-test-file-name

16187429test-file-name

 

你可以在你想對那些像上面一樣的糟糕命名的檔案做某些操作時使用這一技術。例如,名為file?.txt的檔案名字中有一個特殊字元。若你想執行“rm file?.txt”,下麵所示的所有三個檔案都會被刪除。所以,採用下麵的步驟來刪除”file?.txt”檔案。

 

ls

file1.txt  file2.txt file?.txt

 

找到每一個檔案的inode編號。

 

ls -i1

804178 file1.txt

804179 file2.txt

804180 file?.txt

 

如下所示:?使用inode編號來刪除那些具有特殊符號的檔案名。

 

find -inum 804180-exec rm {} ;

# ls

file1.txt  file2.txt

[Note: The file withname “file?.txt” is now removed]

 

7. 根據檔案許可權查詢檔案

 

下麵的操作時合理的:

 

    找到具有指定許可權的檔案

    忽略其他許可權位,檢查是否和指定許可權匹配

    根據給定的八進位制/符號表達的許可權搜尋

 

此例中,假設目錄包含以下檔案。註意這些檔案的許可權不同。

 

ls -l

total 0

-rwxrwxrwx 1 rootroot 0 2009-02-19 20:31 all_for_all

-rw-r–r– 1 rootroot 0 2009-02-19 20:30 everybody_read

———- 1 rootroot 0 2009-02-19 20:31 no_for_all

-rw——- 1 rootroot 0 2009-02-19 20:29 ordinary_file

-rw-r—– 1 rootroot 0 2009-02-19 20:27 others_can_also_read

—-r—– 1 rootroot 0 2009-02-19 20:27 others_can_only_read

 

找到具有組讀許可權的檔案。使用下麵的命令來找到當前目錄下對同組使用者具有讀許可權的檔案,忽略該檔案的其他許可權。

 

find . -perm -g=r-type f -exec ls -l {} ;

-rw-r–r– 1 rootroot 0 2009-02-19 20:30 ./everybody_read

-rwxrwxrwx 1 rootroot 0 2009-02-19 20:31 ./all_for_all

—-r—– 1 rootroot 0 2009-02-19 20:27 ./others_can_only_read

-rw-r—– 1 rootroot 0 2009-02-19 20:27 ./others_can_also_read

 

找到對組使用者具有隻讀許可權的檔案。

 

find . -perm g=r-type f -exec ls -l {} ;

—-r—– 1 rootroot 0 2009-02-19 20:27 ./others_can_only_read

 

找到對組使用者具有隻讀許可權的檔案(使用八進位制許可權形式)

 

find . -perm 040-type f -exec ls -l {} ;

—-r—– 1 rootroot 0 2009-02-19 20:27 ./others_can_only_read

 

8. 找到home目錄及子目錄下所有的空檔案(0位元組檔案)

 

下麵命令的輸出檔案絕大多數都是鎖定檔案盒其他程式建立的place hoders

 

find ~ -empty

 

只列出你home目錄裡的空檔案。

 

find . -maxdepth 1-empty

 

只列出當年目錄下的非隱藏空檔案。

 

find . -maxdepth 1-empty -not -name “.*”

 

9. 查詢5個最大的檔案

 

下麵的命令列出當前目錄及子目錄下的5個最大的檔案。這會需要一點時間,取決於命令需要處理的檔案數量。

 

find . -type f -execls -s {} ; | sort -n -r | head -5

 

10. 查詢5個最小的檔案

 

方法同查詢5個最大的檔案類似,區別隻是sort的順序是降序。

 

find . -type f -execls -s {} ; | sort -n  | head -5

 

上面的命令中,很可能你看到的只是空檔案(0位元組檔案)。如此,你可以使用下麵的命令列出最小的檔案,而不是0位元組檔案。

 

find . -not -empty-type f -exec ls -s {} ; | sort -n  |head -5

 

11. 使用-type查詢指定檔案型別的檔案

 

只查詢socket檔案

 

find . -type s

 

查詢所有的目錄

 

find . -type d

 

查詢所有的一般檔案

 

find . -type f

 

查詢所有的隱藏檔案

 

find . -type f -name”.*”

 

查詢所有的隱藏目錄

 

find -type d -name”.*”

 

12. 透過和其他檔案比較修改時間查詢檔案

 

顯示在指定檔案之後做出修改的檔案。下麵的find命令將顯示所有的在ordinary_file之後建立修改的檔案。

 

ls -lrt

total 0

-rw-r—– 1 rootroot 0 2009-02-19 20:27 others_can_also_read

—-r—– 1 rootroot 0 2009-02-19 20:27 others_can_only_read

-rw——- 1 rootroot 0 2009-02-19 20:29 ordinary_file

-rw-r–r– 1 rootroot 0 2009-02-19 20:30 everybody_read

-rwxrwxrwx 1 rootroot 0 2009-02-19 20:31 all_for_all

———- 1 rootroot 0 2009-02-19 20:31 no_for_all

 

# find -newerordinary_file

.

./everybody_read

./all_for_all

./no_for_all

 

13. 透過檔案大小查詢檔案

 

使用-size選項可以透過檔案大小查詢檔案。

 

查詢比指定檔案大的檔案

 

find ~ -size +100M

 

查詢比指定檔案小的檔案

 

find ~ -size -100M

 

查詢符合給定大小的檔案

 

find ~ -size 100M

 

註意: – 指比給定尺寸小,+ 指比給定尺寸大。沒有符號代表和給定尺寸完全一樣大。

14. 給常用find操作取別名

 

若你發現有些東西很有用,你可以給他取別名。並且在任何你希望的地方執行。

 

常用的刪除a.out檔案。

 

aliasrmao=”find . -iname a.out -exec rm {} ;”

# rmao

 

刪除c程式產生的core檔案。

 

alias rmc=”find. -iname core -exec rm {} ;”

# rmc

 

15. find命令刪除大型打包檔案

 

下麵的命令刪除大於100M*.zip檔案。

 

find / -type f -name*.zip -size +100M -exec rm -i {} ;”

 

用別名rm100m刪除所有大雨100M*.tar檔案。使用同樣的思想可以建立rm1g,rm2g,rm5g的一類別名來刪除所有大於1G,2G,5G的檔案。

 

aliasrm100m=”find / -type f -name *.tar -size +100M -exec rm -i {} ;”

# aliasrm1g=”find / -type f -name *.tar -size +1G -exec rm -i {} ;”

# aliasrm2g=”find / -type f -name *.tar -size +2G -exec rm -i {} ;”

# aliasrm5g=”find / -type f -name *.tar -size +5G -exec rm -i {} ;”

 

# rm100m

# rm1g

# rm2g

# rm5g

 

基於訪問/修改/更改時間查詢檔案

 

你可以找到基於以下三個檔案的時間屬性的檔案。

 

    訪問時間的檔案。檔案訪問時,訪問時間得到更新。

    的檔案的修改時間。檔案內容修改時,修改時間得到更新。

    更改檔案的時間。更改時間時,被更新的inode資料的變化。

 

在下麵的例子中,min選項之間的差異和時間選項是引數。

 

分論點將它的引數為分鐘。例如,60分鐘(1小時)= 60分鐘。時間引數,將它的引數為24小時。例如,時間2 = 2 * 24小時(2天)。雖然這樣做的24個小時計算,小數部分都將被忽略,所以25小時為24小時,和47小時取為24小時,僅48小時為48小時。要獲得更清晰的參考atime的部分find命令的手冊頁。

 

16.找到在1個小時內被更改的檔案

 

想要透過檔案修改時間找出檔案,可以使用引數 -mmin -mtime。下麵是man手冊中有關mminmtime的定義。

 

-mmin n 檔案最後一次修改是在n分鐘之內

-mtime n 檔案最後一次修改是在 n*24小時之內(譯者註:也就是n天了唄)

 

執行下麵例子中的命令,將會找到當前目錄以及其子目錄下,最近一次修改時間在1個小時(60分鐘)之內的檔案或目錄

 

# find . -amin -60

 

同樣的方式,執行下麵例子中的命令,將會找到24小時(1天)內被訪問了的檔案(檔案系統根目錄 / 下)

 

# find / -atime -1

 

17.找到1個小時內被訪問過的檔案

 

想要透過檔案訪問時間找出檔案,可以使用引數 -amin -atime。下麵是man手冊中有關aminatime的定義。

 

-amin n 檔案最後一次訪問是在n分鐘之內

-atime n 檔案最後一次訪問是在 n*24小時之內

 

執行下麵例子中的命令,將會找到當前目錄以及其子目錄下,最近一次訪問時間在1個小時(60分鐘)之內的檔案或目錄

 

# find . -amin -60

 

同樣的方式,執行下麵例子中的命令,將會找到24小時(1天)內被訪問了的檔案(檔案系統根目錄 / 下)

 

# find / -atime -1

 

18.查詢一個小時內狀態被改變的檔案

 

(譯者註:這裡的改變更第1個例子的更改檔案內容時間是不同概念,這裡是更改的是檔案inode的資料,比如檔案的許可權,所屬人等等資訊)

 

要查詢檔案的inode的更改時間,使用-cmin-ctime選項

 

-cmin n  檔案的狀態在n分鐘內被改變

-ctime n  檔案狀態在n*24小時內(也就是n天內)被改變

 

(譯者註:如果上面的n-n形式,則表示n分鐘/天之內,n+n則表示n分鐘/天之前)

 

下麵的例子在當前目錄和其子目錄下麵查詢一個小時內檔案狀態改變的檔案(也就是60分鐘內):

 

# find . -cmin -60

 

同樣的道理,下麵的例子在根目錄/及其子目錄下一天內(24小時內)檔案狀態被改變的檔案串列:

 

# find / -ctime -1

 

19.搜尋僅僅限定於檔案,不顯示檔案夾

 

上面的例子搜尋出來不僅僅有檔案,還會顯示檔案夾。因為當一個檔案被訪問的時候,它所處的檔案夾也會被訪問,如果你對檔案夾不感興趣,那麼可以使用 -type f 選項

 

下麵的例子會顯示30分鐘內被修改過的檔案,檔案夾不顯示:

 

# find/etc/sysconfig -amin -30

.

./console

./network-scripts

./i18n

./rhn

./rhn/clientCaps.d

./networking

./networking/profiles

./networking/profiles/default

./networking/profiles/default/resolv.conf

./networking/profiles/default/hosts

./networking/devices

./apm-scripts

[: 上面的輸出包含了檔案和檔案夾]

 

# find/etc/sysconfig -amin -30 -type f

./i18n

./networking/profiles/default/resolv.conf

./networking/profiles/default/hosts

[: 上面的輸出僅僅包含檔案]

 

20.僅僅查詢非隱藏的檔案(不顯示隱藏檔案):

 

如果我們查詢的時候不想隱藏檔案也顯示出來,可以使用下麵的正則式查詢:

 

下麵的命令會顯示當前目錄及其子目錄下15分鐘內檔案內容被修改過的檔案,並且只列出非隱藏檔案。也就是說,以.開頭的檔案時不會顯示出來的

 

# find . -mmin -15( ! -regex “.*/..*” )

 

基於檔案比較的查詢命令

 

我們平時透過更別的東西進行比較,會更容易記住一些事情。比如說我想找出在我編輯test檔案之後編輯過的檔案。你可以透過test這個檔案的編輯時間作為比較基準去查詢之後編輯過的檔案:

21.查詢檔案修改時間在某一檔案修改後的檔案:

 

語法: find -newerFILE

 

下麵的例子顯示在/etc/passwd修改之後被修改過的檔案。對於系統管理員,想知道你新增了一個使用者後去跟蹤系統的活動狀態是很有幫助的(萬一那新使用者不老實,一上來就亂搞,你很快就知道了 ^_^):

 

# find -newer/etc/passwd

 

22.查詢檔案訪問時間在某一檔案的修改時間之後的檔案:

 

# find -newer/etc/passwd

 

下麵的例子顯示所有在/etc/hosts檔案被修改後被訪問到的檔案。如果你新增了一個主機/埠記錄在/etc/hosts檔案中,你很可能很想知道在那之後有什麼檔案被訪問到了,下麵是這個命令:

 

# find -anewer/etc/hosts

 

23.查詢狀態改變時間在某個檔案修改時間之後的檔案:

 

語法: find -cnewerFILE

 

下麵的例子顯示在修改檔案/etc/fstab之後所有檔案狀態改變過的檔案。如果你在/etc/fstab新增了一個掛載點,你很可能想知道之後哪些檔案的狀態發生了改變,這時候你可以使用如下命令:

 

# find -cnewer/etc/fstab

 

在查詢到的檔案串列結果上直接執行命令:

 

這之前你已經看到瞭如果透過find命令去查詢各種條件的檔案串列。如果你對這些find命令還不熟悉,我建議你看完上面的第一部分

 

接下來這部分我們向你介紹如果在find命令上執行各種不同的命令,也就是說如何去操作find命令查找出來的檔案串列。

 

我們能在find命令查找出來的檔案名串列上指定任意的操作:

 

# find -exec ;

 

其中的OPERATION可以是任意的命令,下麵列舉一下比較常用的:

 

 rm 命令,用於刪除find查找出來的檔案

 mv 命令,用於重新命名查找出的檔案

 ls -l 命令,顯示查找出的檔案的詳細資訊

 md5sum,對查找出的檔案進行md5sum運算,可以獲得一個字串,用於檢測檔案內容的合法性

 wc 命令,用於統計計算檔案的單詞數量,檔案大小等待

 執行任何UnixShell命令

 執行你自己寫的shell指令碼,引數就是每個查找出來的檔案名

24.find命令輸出上使用 ls-l,列舉出1小時內被編輯過的檔案的詳細資訊

 

# find -mmin -60

./cron

./secure

 

 # find -mmin -60 -exec ls -l {} ;

-rw——-  1 root root 1028 Jun 21 15:01 ./cron

-rw——-  1 root root 831752 Jun 21 15:42 ./secure

 

25.僅僅在當前檔案系統中搜索

 

系統管理員有時候僅僅想在/掛載的檔案系統分割槽上搜索,而不想去搜索其他的掛載分割槽,比如/home/掛載分割槽。如果你有多個分割槽被掛載了,你想在/下搜尋,一般可以按下麵的這樣做

 

下麵這個命令會搜尋根目錄/及其子目錄下所有.log結尾的檔案名。如果你有多個分割槽在/下麵,那麼這個搜尋會去搜索所有的被掛載的分割槽:

 

# find / -name”*.log”

 

如果我們使用-xdev選項,那麼僅僅會在在當前檔案系統中搜索,下麵是在xdevmanpage上面找到的一段-xdev的定義:

 

-xdev Don’t descenddirectories on other filesystems.

 

下麵的命令會在/目錄及其子目錄下搜尋當前檔案系統(也就是/掛載的檔案系統)中所有以.log結尾的檔案,也就是說如果你有多個分割槽掛載在/下麵,下麵的搜尋不會去搜索其他的分割槽的(比如/home/

 

# find / -xdev -name”*.log”

 

26.在同一個命令中使用多個{}

 

linux手冊說命令中只能使用一個{},不過你可以像下麵這樣在同一個命令中使用多個{}

 

# find -name”*.txt” cp {} {}.bkup ;

 

註意,在同一個命令中使用這個{}是可以的,但是在不同的命令裡就不行了,也就是說,如果你想象下麵這樣重新命名檔案是行不通的

 

find -name”*.txt” -exec mv {} `basename {} .htm`.html ;

 

27. 使用多個{}實體

 

你可以像下麵這樣寫一個shell指令碼去模擬上面那個重新命名的例子

 

# mv “$1″”`basename “$1″ .htm`.html”

 

上面的雙引號是為了防止檔案名中出現的空格,不加的話會有問題。然後你把這個shell指令碼儲存為mv.sh,你可以像下麵這樣使用find命令了

 

find -name”*.html” -exec ./mv.sh ‘{}’ ;

 

所以,任何情況下你在find命令執行中想使用同一個檔案名多次的話,先寫一個指令碼,然後在find中透過-exec執行這個指令碼,把檔案名引數傳遞進去就行,這是最簡單的辦法

28.將錯誤重定向到/dev/nul

 

重定向錯誤輸出一般不是什麼好的想法。一個有經驗的程式員懂得在終端顯示錯誤並及時修正它是很重要的。

 

尤其是在find命令中重定向錯誤不是個好的實踐。但是如果你確實不想看到那些煩人的錯誤,想把錯誤都重定向到null裝置中(也就是linux上的黑洞裝置,任何丟進去的東西消失的無影無蹤了)。你可以像下麵這樣做

 

find -name”*.txt” 2>>/dev/null

 

有時候這是很有用的。比如,如果你想透過你自己的賬號在/目錄下查詢所有的*.conf檔案,你會得到很多很多的”Permission denied”的錯誤訊息,就像下麵這樣:

 

$ find / -name”*.conf”

/sbin/generate-modprobe.conf

find:/tmp/orbit-root: Permission denied

find:/tmp/ssh-gccBMp5019: Permission denied

find:/tmp/keyring-5iqiGo: Permission denied

find:/var/log/httpd: Permission denied

find: /var/log/ppp:Permission denied

/boot/grub/grub.conf

find:/var/log/audit: Permission denied

find:/var/log/squid: Permission denied

find:/var/log/samba: Permission denied

find:/var/cache/alchemist/printconf.rpm/wm: Permission denied

[Note: There are twovalid *.conf files burned in the “Permission denied” messages]

 

你說煩人不?所以,如果你只想看到find命令真實的查詢結果而不是這些”Permission denied”錯誤訊息,你可以將這些錯誤訊息重定向到/dev/null中去

 

$ find / -name”*.conf” 2>>/dev/null

/sbin/generate-modprobe.conf

/boot/grub/grub.conf

[Note: All the”Permission denied” messages are not displayed]

 

29.將檔案名中的空格換成下劃線

 

你從網上下載下來的音訊檔案的檔案名很多都帶有空格。但是帶有空格的檔案名在linux(Unix)系統裡面是很不好的。你可以使用find然後後面加上rename命令的替換功能去重新命名這些檔案,將空格轉換成下劃線

 

下麵顯示怎樣將所有mp3檔案的檔案名中的空格換成_

 

$ find . -type f-iname “*.mp3″ -exec rename “s/ /_/g” {} ;

 

30.find結果中同時執行兩條命令

 

findman page頁面中,下麵是一次檔案查詢遍歷中使用兩條命令的語法舉例

 

下麵的find命令的例子,遍歷檔案系統一次,列出擁有setuid屬性的檔案和目錄,寫入/root/suid.txt檔案,如果檔案大小超過100M,將其記錄到/root/big.txt

 

# find / ( -perm-4000 -fprintf /root/suid.txt ‘%#m %u %p
‘ ) ,

( -size +100M-fprintf /root/big.txt ‘%-10s %p
‘ )

 

 

31、常用指令

find /backup/rman_backup/ -mtime +45 -exec rm -rf {} ;  刪除45天前的檔案

find /tmp -mtime +7-size +1M -exec rm -rf {} ;

find -mtime +7 -nameabc* -exec rm -rf {} ;

find /tmp -mtime +7-size +1M -ok rm -rf {} ;

 

 


●本文編號398,以後想閱讀這篇文章直接輸入398即可

●輸入m獲取到文章目錄

推薦↓↓↓

運維

更多推薦18個技術類公眾微信

涵蓋:程式人生、演演算法與資料結構、駭客技術與網路安全、大資料技術、前端開發、Java、Python、Web開發、安卓開發、iOS開發、C/C++、.NET、Linux、資料庫、運維等。

贊(0)

分享創造快樂