您好,登錄后才能下訂單哦!
小編給大家分享一下Linux中find命令的使用示例有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
一、主要內(nèi)容
1. 用文件名查找文件
2.用文件名查找文件,忽略大小寫
3. 使用mindepth和maxdepth限定搜索指定目錄的深度
4. 在find命令查找到的文件上執(zhí)行命令
5. 相反匹配
6. 使用inode編號查找文件
7. 根據(jù)文件權(quán)限查找文件
8. 找到home目錄及子目錄下所有的空文件(0字節(jié)文件)
9. 查找5個***的文件
10. 查找5個最小的文件
11. 使用-type查找指定文件類型的文件
12. 通過和其他文件比較修改時間查找文件
13. 通過文件大小查找文件
14. 給常用find操作取別名
15. 用find命令刪除大型打包文件
16.找到在1個小時內(nèi)被更改的文件
17.找到1個小時內(nèi)被訪問過的文件
18.查找一個小時內(nèi)狀態(tài)被改變的文件
19.搜索僅僅限定于文件,不顯示文件夾
20.僅僅查找非隱藏的文件(不顯示隱藏文件)
21.查找文件修改時間在某一文件修改后的文件
22.查找文件訪問時間在某一文件的修改時間之后的文件
23.查找狀態(tài)改變時間在某個文件修改時間之后的文件:
24.在find命令輸出上使用 ls -l,列舉出1小時內(nèi)被編輯過的文件的詳細(xì)信息
25.僅僅在當(dāng)前文件系統(tǒng)中搜索
26.在同一個命令中使用多個{}
27. 使用多個{}實例
28.將錯誤重定向到/dev/nul
29.將文件名中的空格換成下劃線
30.在find結(jié)果中同時執(zhí)行兩條命令
31、常用指令
二、find命令實用實例總結(jié)
(一)、基于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"
(二)、基于權(quán)限查詢文件
# 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 {} \;
三、詳細(xì)信息
除了在一個目錄結(jié)構(gòu)下查找文件這種基本的操作,你還可以用find命令實現(xiàn)一些實用的操作,使你的命令行之旅更加簡易。本文將介紹31種無論是于新手還是老鳥都非常有用的Linux find命令。
首先,在你的home目錄下面創(chuàng)建下面的空文件,來測試下面的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作為查找名在當(dāng)前目錄及其子目錄中查找文件的方法。
# find -name"MyCProgram.c"
./backup/MyCProgram.c
./MyCProgram.c
2.用文件名查找文件,忽略大小寫
這是find命令的一個基本用法。下面的例子展示了用MyCProgram.c作為查找名在當(dāng)前目錄及其子目錄中查找文件的方法,忽略了大小寫。
# find -iname"MyCProgram.c"
./mycprogram.c
./backup/mycprogram.c
./backup/MyCProgram.c
./MyCProgram.c
3. 使用mindepth和maxdepth限定搜索指定目錄的深度
在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命令查找到的文件上執(zhí)行命令
下面的例子展示了find命令來計算所有不區(qū)分大小寫的文件名為“MyCProgram.c”的文件的MD5驗證和。{}將會被當(dāng)前文件名取代。
find -iname"MyCProgram.c" -exec md5sum {} \;
d41d8cd98f00b204e9800998ecf8427e ./mycprogram.c
d41d8cd98f00b204e9800998ecf8427e ./backup/mycprogram.c
d41d8cd98f00b204e9800998ecf8427e ./backup/MyCProgram.c
d41d8cd98f00b204e9800998ecf8427e ./MyCProgram.c
5. 相反匹配
顯示所有的名字不是MyCProgram.c的文件或者目錄。由于maxdepth是1,所以只會顯示當(dāng)前目錄下的文件和目錄。
find -maxdepth 1-not -iname "MyCProgram.c"
.
./MybashProgram.sh
./create_sample_files.sh
./backup
./Program.c
6. 使用inode編號查找文件
任何一個文件都有一個***的inode編號,借此我們可以區(qū)分文件。創(chuàng)建兩個名字相似的文件,例如一個有空格結(jié)尾,一個沒有。
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的輸出不能區(qū)分哪個文件有空格結(jié)尾。使用選項-i,可以看到文件的inode編號,借此可以區(qū)分這兩個文件。
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
你可以在你想對那些像上面一樣的糟糕命名的文件做某些操作時使用這一技術(shù)。例如,名為file?.txt的文件名字中有一個特殊字符。若你想執(zhí)行“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. 根據(jù)文件權(quán)限查找文件
下面的操作時合理的:
找到具有指定權(quán)限的文件
忽略其他權(quán)限位,檢查是否和指定權(quán)限匹配
根據(jù)給定的八進(jìn)制/符號表達(dá)的權(quán)限搜索
此例中,假設(shè)目錄包含以下文件。注意這些文件的權(quán)限不同。
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
找到具有組讀權(quán)限的文件。使用下面的命令來找到當(dāng)前目錄下對同組用戶具有讀權(quán)限的文件,忽略該文件的其他權(quán)限。
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
找到對組用戶具有只讀權(quán)限的文件。
find . -perm g=r-type f -exec ls -l {} \;
----r----- 1 rootroot 0 2009-02-19 20:27 ./others_can_only_read
找到對組用戶具有只讀權(quán)限的文件(使用八進(jìn)制權(quán)限形式)。
find . -perm 040-type f -exec ls -l {} \;
----r----- 1 rootroot 0 2009-02-19 20:27 ./others_can_only_read
8. 找到home目錄及子目錄下所有的空文件(0字節(jié)文件)
下面命令的輸出文件絕大多數(shù)都是鎖定文件盒其他程序創(chuàng)建的place hoders
find ~ -empty
只列出你home目錄里的空文件。
find . -maxdepth 1-empty
只列出當(dāng)年目錄下的非隱藏空文件。
find . -maxdepth 1-empty -not -name ".*"
9. 查找5個***的文件
下面的命令列出當(dāng)前目錄及子目錄下的5個***的文件。這會需要一點時間,取決于命令需要處理的文件數(shù)量。
find . -type f -execls -s {} \; | sort -n -r | head -5
10. 查找5個最小的文件
方法同查找5個***的文件類似,區(qū)別只是sort的順序是降序。
find . -type f -execls -s {} \; | sort -n | head -5
上面的命令中,很可能你看到的只是空文件(0字節(jié)文件)。如此,你可以使用下面的命令列出最小的文件,而不是0字節(jié)文件。
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之后創(chuàng)建修改的文件。
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操作取別名
若你發(fā)現(xiàn)有些東西很有用,你可以給他取別名。并且在任何你希望的地方執(zhí)行。
常用的刪除a.out文件。
aliasrmao="find . -iname a.out -exec rm {} \;"
# rmao
刪除c程序產(chǎn)生的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文件。使用同樣的思想可以創(chuàng)建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
基于訪問/修改/更改時間查找文件
你可以找到基于以下三個文件的時間屬性的文件。
訪問時間的文件。文件訪問時,訪問時間得到更新。
的文件的修改時間。文件內(nèi)容修改時,修改時間得到更新。
更改文件的時間。更改時間時,被更新的inode數(shù)據(jù)的變化。
在下面的例子中,min選項之間的差異和時間選項是參數(shù)。
分論點將它的參數(shù)為分鐘。例如,60分鐘(1小時)= 60分鐘。時間參數(shù),將它的參數(shù)為24小時。例如,時間2 = 2 * 24小時(2天)。雖然這樣做的24個小時計算,小數(shù)部分都將被忽略,所以25小時為24小時,和47小時取為24小時,僅48小時為48小時。要獲得更清晰的參考atime的部分find命令的手冊頁。
16.找到在1個小時內(nèi)被更改的文件
想要通過文件修改時間找出文件,可以使用參數(shù) -mmin -mtime。下面是man手冊中有關(guān)mmin和mtime的定義。
-mmin n 文件***一次修改是在n分鐘之內(nèi)
-mtime n 文件***一次修改是在 n*24小時之內(nèi)(譯者注:也就是n天了唄)
執(zhí)行下面例子中的命令,將會找到當(dāng)前目錄以及其子目錄下,最近一次修改時間在1個小時(60分鐘)之內(nèi)的文件或目錄
# find . -amin -60
同樣的方式,執(zhí)行下面例子中的命令,將會找到24小時(1天)內(nèi)被訪問了的文件(文件系統(tǒng)根目錄 / 下)
# find / -atime -1
17.找到1個小時內(nèi)被訪問過的文件
想要通過文件訪問時間找出文件,可以使用參數(shù) -amin -atime。下面是man手冊中有關(guān)amin和atime的定義。
-amin n 文件***一次訪問是在n分鐘之內(nèi)
-atime n 文件***一次訪問是在 n*24小時之內(nèi)
執(zhí)行下面例子中的命令,將會找到當(dāng)前目錄以及其子目錄下,最近一次訪問時間在1個小時(60分鐘)之內(nèi)的文件或目錄
# find . -amin -60
同樣的方式,執(zhí)行下面例子中的命令,將會找到24小時(1天)內(nèi)被訪問了的文件(文件系統(tǒng)根目錄 / 下)
# find / -atime -1
18.查找一個小時內(nèi)狀態(tài)被改變的文件
(譯者注:這里的改變更第1個例子的更改文件內(nèi)容時間是不同概念,這里是更改的是文件inode的數(shù)據(jù),比如文件的權(quán)限,所屬人等等信息)
要查找文件的inode的更改時間,使用-cmin和-ctime選項
-cmin n 文件的狀態(tài)在n分鐘內(nèi)被改變
-ctime n 文件狀態(tài)在n*24小時內(nèi)(也就是n天內(nèi))被改變
(譯者注:如果上面的n為-n形式,則表示n分鐘/天之內(nèi),n為+n則表示n分鐘/天之前)
下面的例子在當(dāng)前目錄和其子目錄下面查找一個小時內(nèi)文件狀態(tài)改變的文件(也就是60分鐘內(nèi)):
# find . -cmin -60
同樣的道理,下面的例子在根目錄/及其子目錄下一天內(nèi)(24小時內(nèi))文件狀態(tài)被改變的文件列表:
# find / -ctime -1
19.搜索僅僅限定于文件,不顯示文件夾
上面的例子搜索出來不僅僅有文件,還會顯示文件夾。因為當(dāng)一個文件被訪問的時候,它所處的文件夾也會被訪問,如果你對文件夾不感興趣,那么可以使用 -type f 選項
下面的例子會顯示30分鐘內(nèi)被修改過的文件,文件夾不顯示:
# 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.僅僅查找非隱藏的文件(不顯示隱藏文件):
如果我們查找的時候不想隱藏文件也顯示出來,可以使用下面的正則式查找:
下面的命令會顯示當(dāng)前目錄及其子目錄下15分鐘內(nèi)文件內(nèi)容被修改過的文件,并且只列出非隱藏文件。也就是說,以.開頭的文件時不會顯示出來的
# find . -mmin -15\( ! -regex ".*/\..*" \)
基于文件比較的查找命令
我們平時通過更別的東西進(jìn)行比較,會更容易記住一些事情。比如說我想找出在我編輯test文件之后編輯過的文件。你可以通過test這個文件的編輯時間作為比較基準(zhǔn)去查找之后編輯過的文件:
21.查找文件修改時間在某一文件修改后的文件:
語法: find -newerFILE
下面的例子顯示在/etc/passwd修改之后被修改過的文件。對于系統(tǒng)管理員,想知道你新增了一個用戶后去跟蹤系統(tǒng)的活動狀態(tài)是很有幫助的(萬一那新用戶不老實,一上來就亂搞,你很快就知道了 ^_^):
# find -newer/etc/passwd
22.查找文件訪問時間在某一文件的修改時間之后的文件:
# find -newer/etc/passwd
下面的例子顯示所有在/etc/hosts文件被修改后被訪問到的文件。如果你新增了一個主機/端口記錄在/etc/hosts文件中,你很可能很想知道在那之后有什么文件被訪問到了,下面是這個命令:
# find -anewer/etc/hosts
23.查找狀態(tài)改變時間在某個文件修改時間之后的文件:
語法: find -cnewerFILE
下面的例子顯示在修改文件/etc/fstab之后所有文件狀態(tài)改變過的文件。如果你在/etc/fstab新增了一個掛載點,你很可能想知道之后哪些文件的狀態(tài)發(fā)生了改變,這時候你可以使用如下命令:
# find -cnewer/etc/fstab
在查找到的文件列表結(jié)果上直接執(zhí)行命令:
這之前你已經(jīng)看到了如果通過find命令去查找各種條件的文件列表。如果你對這些find命令還不熟悉,我建議你看完上面的***部分
接下來這部分我們向你介紹如果在find命令上執(zhí)行各種不同的命令,也就是說如何去操作find命令查找出來的文件列表。
我們能在find命令查找出來的文件名列表上指定任意的操作:
# find <CONDITIONto Find files> -exec <OPERATION> \;
其中的OPERATION可以是任意的命令,下面列舉一下比較常用的:
rm 命令,用于刪除find查找出來的文件
mv 命令,用于重命名查找出的文件
ls -l 命令,顯示查找出的文件的詳細(xì)信息
md5sum,對查找出的文件進(jìn)行md5sum運算,可以獲得一個字符串,用于檢測文件內(nèi)容的合法性
wc 命令,用于統(tǒng)計計算文件的單詞數(shù)量,文件大小等待
執(zhí)行任何Unix的Shell命令
執(zhí)行你自己寫的shell腳本,參數(shù)就是每個查找出來的文件名
24.在find命令輸出上使用 ls-l,列舉出1小時內(nèi)被編輯過的文件的詳細(xì)信息
# 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.僅僅在當(dāng)前文件系統(tǒng)中搜索
系統(tǒng)管理員有時候僅僅想在/掛載的文件系統(tǒng)分區(qū)上搜索,而不想去搜索其他的掛載分區(qū),比如/home/掛載分區(qū)。如果你有多個分區(qū)被掛載了,你想在/下搜索,一般可以按下面的這樣做
下面這個命令會搜索根目錄/及其子目錄下所有.log結(jié)尾的文件名。如果你有多個分區(qū)在/下面,那么這個搜索會去搜索所有的被掛載的分區(qū):
# find / -name"*.log"
如果我們使用-xdev選項,那么僅僅會在在當(dāng)前文件系統(tǒng)中搜索,下面是在xdev的manpage上面找到的一段-xdev的定義:
-xdev Don’t descenddirectories on other filesystems.
下面的命令會在/目錄及其子目錄下搜索當(dāng)前文件系統(tǒng)(也就是/掛載的文件系統(tǒng))中所有以.log結(jié)尾的文件,也就是說如果你有多個分區(qū)掛載在/下面,下面的搜索不會去搜索其他的分區(qū)的(比如/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"
上面的雙引號是為了防止文件名中出現(xiàn)的空格,不加的話會有問題。然后你把這個shell腳本保存為mv.sh,你可以像下面這樣使用find命令了
find -name"*.html" -exec ./mv.sh '{}' \;
所以,任何情況下你在find命令執(zhí)行中想使用同一個文件名多次的話,先寫一個腳本,然后在find中通過-exec執(zhí)行這個腳本,把文件名參數(shù)傳遞進(jìn)去就行,這是最簡單的辦法
28.將錯誤重定向到/dev/nul
重定向錯誤輸出一般不是什么好的想法。一個有經(jīng)驗的程序員懂得在終端顯示錯誤并及時修正它是很重要的。
尤其是在find命令中重定向錯誤不是個好的實踐。但是如果你確實不想看到那些煩人的錯誤,想把錯誤都重定向到null設(shè)備中(也就是linux上的黑洞裝置,任何丟進(jìn)去的東西消失的無影無蹤了)。你可以像下面這樣做
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命令真實的查找結(jié)果而不是這些”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.將文件名中的空格換成下劃線
你從網(wǎng)上下載下來的音頻文件的文件名很多都帶有空格。但是帶有空格的文件名在linux(類Unix)系統(tǒng)里面是很不好的。你可以使用find然后后面加上rename命令的替換功能去重命名這些文件,將空格轉(zhuǎn)換成下劃線
下面顯示怎樣將所有mp3文件的文件名中的空格換成_
$ find . -type f-iname “*.mp3″ -exec rename “s/ /_/g” {} \;
30.在find結(jié)果中同時執(zhí)行兩條命令
在find的man page頁面中,下面是一次文件查找遍歷中使用兩條命令的語法舉例
下面的find命令的例子,遍歷文件系統(tǒng)一次,列出擁有setuid屬性的文件和目錄,寫入/root/suid.txt文件,如果文件大小超過100M,將其記錄到/root/big.txt中
# find / \( -perm-4000 -fprintf /root/suid.txt '%#m %u %p\n' \) , \
\( -size +100M-fprintf /root/big.txt '%-10s %p\n' \)
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 {} \;
以上是“Linux中find命令的使用示例有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。