歡迎您光臨本站 註冊首頁

《linux與unix shell編程》之Linux文件查找命令find,xargs詳述

←手機掃碼閱讀     火星人 @ 2014-03-24 , reply:0

Linux文件查找命令find,xargs詳述
1.find
由於f i n d具有強大的功能,所以它的選項也很多,其中大部分選項都值得我們花時間來了解一下。即使系統中含有網路文件系統( N F S ),f i n d命令在該文件系統中同樣有效,只你具有相應的許可權。
在運行一個非常消耗資源的f i n d命令時,很多人都傾向於把它放在後台執行,因為遍歷一個大的文件系統可能會花費很長的時間(這裡是指3 0 G位元組以上的文件系統)。

F i n d命令的一般形式為:
find pathname -options [-print -exec -ok ...]



讓我們來看看該命令的參數:

pathname: find命令所查找的目錄路徑。例如用.來表示當前目錄,用/來表示系統根目錄。
-print: find命令將匹配的文件輸出到標準輸出。
-exec: find命令對匹配的文件執行該參數所給出的s h e l l命令。相應命令的形式為' command' {} \;,注意{ }和\;之間的空格。
-ok: 和- e x e c的作用相同,只不過以一種更為安全的模式來執行該參數所給出的s h e l l命令,在執行每一個命令之前,都會給出提示,讓用戶來確定是否執行。



find命令選項
-name:按照文件名查找文件。
-perm:按照文件許可權來查找文件。
-prune:使用這一選項可以使f i n d命令不在當前指定的目錄中查找,如果同時使用-depth選項,那麼-prune將被f i n d命令忽略。
-user: 按照文件屬主來查找文件。
-group:按照文件所屬的組來查找文件。
-mtime -n +n:按照文件的更改時間來查找文件, - n表示文件更改時間距現在n天以內,+ n表示文件更改時間距現在n天以前。F i n d命令還有- a t i m e和- c t i m e選項,但它們都和- m t i m e選項。
-nogroup:查找無有效所屬組的文件,即該文件所屬的組在/ e t c / g r o u p s中不存在。
-nouser:查找無有效屬主的文件,即該文件的屬主在/ e t c / p a s s w d中不存在。
-newer file1 ! file2:查找更改時間比文件f i l e 1新但比文件f i l e 2舊的文件。
-type 查找某一類型的文件,諸如:

b - 塊設備文件。
d - 目錄。
c - 字元設備文件。
p - 管道文件。
l - 符號鏈接文件。
f - 普通文件。

-size n:[c] 查找文件長度為n塊的文件,帶有c時表示文件長度以位元組計。
-depth:在查找文件時,首先查找當前目錄中的文件,然後再在其子目錄中查找。
-fstype:查找位於某一類型文件系統中的文件,這些文件系統類型通常可以在配置文件/ e t c / f s t a b中找到,該配置文件中包含了本系統中有關文件系統的信息。

-mount:在查找文件時不跨越文件系統m o u n t點。
-follow:如果f i n d命令遇到符號鏈接文件,就跟蹤至鏈接所指向的文件。
-cpio:對匹配的文件使用c p i o命令,將這些文件備份到磁帶設備中。


另外,下面三個的區別:
-amin n

  查找系統中最後N分鐘訪問的文件

  -atime n

  查找系統中最後n*24小時訪問的文件

  -cmin n

  查找系統中最後N分鐘被改變文件狀態的文件

  -ctime n

  查找系統中最後n*24小時被改變文件狀態的文件

 -mmin n

  查找系統中最後N分鐘被改變文件數據的文件

  -mtime n

  查找系統中最後n*24小時被改變文件數據的文件



使用exec或ok來執行shell命令
使用find時,只要把想要的操作寫在一個文件里,就可以用exec來配合find查找,很方便的

(在有些操作系統中只允許- e x e c選項執行諸如l s或ls -l這樣的命令)。大多數用戶使用這一選項是為了查找舊文件並刪除它們。建議在真正執行r m命令刪除文件之前,最好先用l s命令看一下,確認它們是所要刪除的文件。

e x e c選項後面跟隨著所要執行的命令或腳本,然後是一對兒{ },一個空格和一個\,最後是一個分號。

為了使用e x e c選項,必須要同時使用p r i n t選項。如果驗證一下f i n d命令,會發現該命令只輸出從當前路徑起的相對路徑及文件名。


例如:為了用ls -l命令列出所匹配到的文件,可以把ls -l命令放在f i n d命令的- e x e c選項中
# 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


上面的例子中,f i n d命令匹配到了當前目錄下的所有普通文件,並在- e x e c選項中使用ls -l命令將它們列出。

在/ l o g s目錄中查找更改時間在5日以前的文件並刪除它們:
$ find logs -type f -mtime +5 -exec rm {} \;


記住,在s h e l l中用任何方式刪除文件之前,應當先查看相應的文件,一定要小心!當使用諸如m v或r m命令時,可以使用- e x e c選項的安全模式。它將在對每個匹配到的文件進行操作之前提示你。

在下面的例子中, f i n d命令在當前目錄中查找所有文件名以. L O G結尾、更改時間在5日以上的文件,並刪除它們,只不過在刪除之前先給出提示。
$ find . -name "*.conf" -mtime +5 -ok rm {} \;
< rm ... ./conf/httpd.conf > ? n


按y鍵刪除文件,按n鍵不刪除。


任何形式的命令都可以在- e x e c選項中使用。

在下面的例子中我們使用g r e p命令。f i n d命令首先匹配所有文件名為" passwd*"的文件,例如passwd、passwd.old、passwd.bak,然後執
行grep命令看看在這些文件中是否存在一個sam用戶。
# find /etc -name "passwd*" -exec grep "sam" {} \;
sam:x:501:501::/usr/sam:/bin/bash




find命令的例子

查找當前用戶主目錄下的所有文件,下面兩種方法都可以使用:
$ find $HOME -print
$ find ~ -print



為了在當前目錄中文件屬主具有讀、寫許可權,並且文件所屬組的用戶和其他用戶具有讀許可權的文件,可以用:
$ find . -type f -perm 644 -exec ls -l {} \;



為了查找系統中所有文件長度為0的普通文件,並列出它們的完整路徑,可以用:
$ find / -type f -size 0 -exec ls -l {} \;



查找/var/logs目錄中更改時間在7日以前的普通文件,並在刪除之前詢問它們:
$ find /var/logs -type f -mtime +7 -ok rm {} \;



為了查找系統中所有屬於root組的文件,可以用:
$find . -group root -exec ls -l {} \;
-rw-r--r-- 1 root root 595 10月 31 01:09 ./fie1




下面的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



為了查找當前文件系統中的所有目錄並排序,可以用:
$ find . -type d |sort



為了查找系統中所有的r m t磁帶設備,可以用:
$ find /dev/rmt -print



2.xargs
在使用f i n d命令的- e x e c選項處理匹配到的文件時, f i n d命令將所有匹配到的文件一起傳遞給e x e c執行。但有些系統對能夠傳遞給e x e c的命令長度有限制,這樣在f i n d命令運行幾分鐘之後,就會出現溢出錯誤。錯誤信息通常是"參數列太長"或"參數列溢出"。這就是x a rg s命令的用處所在,特別是與f i n d命令一起使用。

F i n d命令把匹配到的文件傳遞給x a rg s命令,而x a rg s命令每次只獲取一部分文件而不是全部,不像- e x e c選項那樣。這樣它可以先處理最先獲取的一部分文件,然後是下一批,並如此繼續下去。

在有些系統中,使用- e x e c選項會為處理每一個匹配到的文件而發起一個相應的進程,並非將匹配到的文件全部作為參數一次執行;這樣在有些情況下就會出現進程過多,系統性能下降的問題,因而效率不高;
而使用x a rg s命令則只有一個進程。另外,在使用x a rg s命令時,究竟是一次獲取所有的參數,還是分批取得參數,以及每一次獲取參數的數目都會根據該命令的選項及系統內核中相應的可調參數來確定。

來看看x a rg s命令是如何同f i n d命令一起使用的,並給出一些例子。

下面的例子查找系統中的每一個普通文件,然後使用x a rg s命令來測試它們分別屬於哪類文件
#find . -type f -print | xargs file
./.kde/Autostart/Autorun.desktop: UTF-8 Unicode English text
./.kde/Autostart/.directory: ISO-8859 text\
......



在整個系統中查找內存信息轉儲文件(core dump) ,然後把結果保存到/tmp/core.log 文件中:
$ find / -name "core" -print | xargs echo "" >/tmp/core.log


上面這個執行太慢,我改成在當前目錄下查找
#find . -name "file*" -print | xargs echo "" > /temp/core.log
# cat /temp/core.log
./file6



在當前目錄下查找所有用戶具有讀、寫和執行許可權的文件,並收回相應的寫許可權:
# ls -l
drwxrwxrwx 2 sam adm 4096 10月 30 20:14 file6
-rwxrwxrwx 2 sam adm 0 10月 31 01:01 http3.conf
-rwxrwxrwx 2 sam adm 0 10月 31 01:01 httpd.conf

# find . -perm -7 -print | xargs chmod o-w
# ls -l
drwxrwxr-x 2 sam adm 4096 10月 30 20:14 file6
-rwxrwxr-x 2 sam adm 0 10月 31 01:01 http3.conf
-rwxrwxr-x 2 sam adm 0 10月 31 01:01 httpd.conf



用g r e p命令在所有的普通文件中搜索hostname這個詞:
# find . -type f -print | xargs grep "hostname"
./httpd1.conf:# different IP addresses or hostnames and have them handled by the
./httpd1.conf:# VirtualHost: If you want to maintain multiple domains/hostnames
on your



用g r e p命令在當前目錄下的所有普通文件中搜索hostnames這個詞:
# find . -name \* -type f -print | xargs grep "hostnames"
./httpd1.conf:# different IP addresses or hostnames and have them handled by the
./httpd1.conf:# VirtualHost: If you want to maintain multiple domains/hostnames
on your


注意,在上面的例子中, \用來取消f i n d命令中的*在s h e l l中的特殊含義。

3.f i n d命令配合使用e x e c和x a rg s可以使用戶對所匹配到的文件執行幾乎所有的命令。

下面是find一些常用參數的例子,有用到的時候查查就行了,像上面前幾個貼子,都用到了其中的的一些參數,也可以用man或查看論壇里其它貼子有find的命令手冊

a.使用name選項

文件名選項是f i n d命令最常用的選項,要麼單獨使用該選項,要麼和其他選項一起使用。
可以使用某種文件名模式來匹配文件,記住要用引號將文件名模式引起來。
不管當前路徑是什麼,如果想要在自己的根目錄$ H O M E中查找文件名符合* . t x t的文件,使用~作為' p a t h n a m e參數,波浪號~代表了你的$ H O M E目錄。
$ find ~ -name "*.txt" -print



想要在當前目錄及子目錄中查找所有的' * . t x t'文件,可以用:
$ find . -name "*.txt" -print



想要的當前目錄及子目錄中查找文件名以一個大寫字母開頭的文件,可以用:
$ find . -name "[A-Z]*" -print



想要在/ e t c目錄中查找文件名以h o s t開頭的文件,可以用:
$ find /etc -name "host*" -print



想要查找$ H O M E目錄中的文件,可以用:
$ find ~ -name "*" -print 或find . -print



要想讓系統高負荷運行,就從根目錄開始查找所有的文件。
$ find / -name "*" -print



如果想在當前目錄查找文件名以兩個小寫字母開頭,跟著是兩個數字,最後是. t x t的文件,下面的命令就能夠返回名為a x 3 7 . t x t的文件:
$find . -name "[a-z][a-z][0--9][0--9].txt" -print




b.用perm選項

按照文件許可權模式用- p e r m選項。

按文件許可權模式來查找文件的話。最好使用八進位的許可權表示法。

如在當前目錄下查找文件許可權位為7 5 5的文件,即文件屬主可以讀、寫、執行,其他用戶可以讀、執行的文件,可以用:
$ find . -perm 755 -print



還有一種表達方法:在八進位數字前面要加一個橫杠-,表示都匹配,如-007就相當於777,-006相當於666
# ls -l
-rwxrwxr-x 2 sam adm 0 10月 31 01:01 http3.conf
-rw-rw-rw- 1 sam adm 34890 10月 31 00:57 httpd1.conf
-rwxrwxr-x 2 sam adm 0 10月 31 01:01 httpd.conf
drw-rw-rw- 2 gem group 4096 10月 26 19:48 sam
-rw-rw-rw- 1 root root 2792 10月 31 20:19 temp

# find . -perm 006
# find . -perm -006
./sam
./httpd1.conf
./temp


-perm mode:文件許可正好符合mode
-perm +mode:文件許可部分符合mode
-perm -mode: 文件許可完全符合mode

c.忽略某個目錄

如果在查找文件時希望忽略某個目錄,因為你知道那個目錄中沒有你所要查找的文件,那麼可以使用- p r u n e選項來指出需要忽略的目錄。在使用- p r u n e選項時要當心,因為如果你同時使用了- d e p t h選項,那麼- p r u n e選項就會被f i n d命令忽略。

如果希望在/ a p p s目錄下查找文件,但不希望在/ a p p s / b i n目錄下查找,可以用:
$ find /apps -path "/apps/bin" -prune -o -print



補充:
使用find查找文件的時候怎麼避開某個文件目錄

比如要在/usr/sam目錄下查找不在dir1子目錄之內的所有文件
find /usr/sam -path "/usr/sam/dir1" -prune -o -print




find [-path ..] [expression] 在路徑列表的後面的是表達式
-path "/usr/sam" -prune -o -print 是 -path "/usr/sam" -a -prune -o -print 的簡寫表達式按順序求值, -a 和 -o 都是短路求值,與 shell 的 && 和 || 類似如果 -path "/usr/sam" 為真,則求值 -prune , -prune 返回真,與邏輯表達式為真;否則不求值 -prune ,與邏輯表達式為假。如果 -path "/usr/sam" -a -prune 為假,則求值 -print ,-print 返回真,或邏輯表達式為真;否則不求值 -print,或邏輯表達式為真。


這個表達式組合特例可以用偽碼寫為

if -path "/usr/sam" then
-prune
else
-print




避開多個文件夾
find /usr/sam \( -path /usr/sam/dir1 -o -path /usr/sam/file1 \) -prune -o -print



圓括弧表示表達式的結合。
\ 表示引用,即指示 shell 不對後面的字元作特殊解釋,而留給 find 命令去解釋其意義。


查找某一確定文件,-name等選項加在-o 之後
#find /usr/sam \(-path /usr/sam/dir1 -o -path /usr/sam/file1 \) -prune -o -name "temp" -print



4.使用user和nouser選項

按文件屬主查找文件,如在$ H O M E目錄中查找文件屬主為sam的文件,可以用:
$ find ~ -user sam -print



在/ e t c目錄下查找文件屬主為u u c p的文件:
$ find /etc -user uucp -print



為了查找屬主帳戶已經被刪除的文件,可以使用- n o u s e r選項。這樣就能夠找到那些屬主在/ e t c / p a s s w d文件中沒有有效帳戶的文件。在使用- n o u s e r選項時,不必給出用戶名; f i n d命令能夠為你完成相應的工作。
例如,希望在/ h o m e目錄下查找所有的這類文件,可以用:
$ find /home -nouser -print



5、使用group和nogroup選項

就像u s e r和n o u s e r選項一樣,針對文件所屬於的用戶組, f i n d命令也具有同樣的選項,為了在/ a p p s目錄下查找屬於gem用戶組的文件,可以用:
$ find /apps -group gem -print



要查找沒有有效所屬用戶組的所有文件,可以使用n o g r o u p選項。下面的f i n d命令從文件系統的根目錄處查找這樣的文件
$ find / -nogroup-print



6、按照更改時間或訪問時間等查找文件

如果希望按照更改時間來查找文件,可以使用m t i m e,atime或ctime選項。如果系統突然沒有可用空間了,很有可能某一個文件的長度在此期間增長迅速,這時就可以用m t i m e選項來查找這樣的文件。
用減號-來限定更改時間在距今n日以內的文件,而用加號+來限定更改時間在距今n日以前的文件。
希望在系統根目錄下查找更改時間在5日以內的文件,可以用:
$ find / -mtime -5 -print



為了在/ v a r / a d m目錄下查找更改時間在3日以前的文件,可以用:
$ find /var/adm -mtime +3 -print



7、查找比某個文件新或舊的文件

如果希望查找更改時間比某個文件新但比另一個文件舊的所有文件,可以使用- n e w e r選項。它的一般形式為:
newest_file_name ! oldest_file_name


其中,!是邏輯非符號。

查找更改時間比文件sam新但比文件temp舊的文件:

例:有兩個文件
-rw-r--r-- 1 sam adm 0 10月 31 01:07 fiel
-rw-rw-rw- 1 sam adm 34890 10月 31 00:57 httpd1.conf
-rwxrwxr-x 2 sam adm 0 10月 31 01:01 httpd.conf
drw-rw-rw- 2 gem group 4096 10月 26 19:48 sam
-rw-rw-rw- 1 root root 2792 10月 31 20:19 temp

# find -newer httpd1.conf ! -newer temp -ls
1077669 0 -rwxrwxr-x 2 sam adm 0 10月 31 01:01 ./httpd.conf
1077671 4 -rw-rw-rw- 1 root root 2792 10月 31 20:19 ./temp
1077673 0 -rw-r--r-- 1 sam adm 0 10月 31 01:07 ./fiel




查找更改時間在比temp文件新的文件:
$ find . -newer temp -print



8、使用type選項

在/ e t c目錄下查找所有的目錄,可以用:
$ find /etc -type d -print



在當前目錄下查找除目錄以外的所有類型的文件,可以用:
$ find . ! -type d -print



在/ e t c目錄下查找所有的符號鏈接文件,可以用:
$ find /etc -type l -print



9、使用size選項

可以按照文件長度來查找文件,這裡所指的文件長度既可以用塊( b l o c k)來計量,也可以用位元組來計量。以位元組計量文件長度的表達形式為N c;以塊計量文件長度只用數字錶示即可。
在按照文件長度查找文件時,一般使用這種以位元組表示的文件長度,在查看文件系統的大小,因為這時使用塊來計量更容易轉換。

在當前目錄下查找文件長度大於1 M位元組的文件:
$ find . -size +1000000c -print



在/ h o m e / a p a c h e目錄下查找文件長度恰好為1 0 0位元組的文件:
$ find /home/apache -size 100c -print



在當前目錄下查找長度超過1 0塊的文件(一塊等於5 1 2位元組):
$ find . -size +10 -print



10、使用depth選項

在使用f i n d命令時,可能希望先匹配所有的文件,再在子目錄中查找。使用d e p t h選項就可以使f i n d命令這樣做。這樣做的一個原因就是,當在使用f i n d命令向磁帶上備份文件系統時,希望首先備份所有的文件,其次再備份子目錄中的文件。

在下面的例子中, f i n d命令從文件系統的根目錄開始,查找一個名為C O N . F I L E的文件。
它將首先匹配所有的文件然後再進入子目錄中查找。
$ find / -name "CON.FILE" -depth -print


11、使用mount選項
在當前的文件系統中查找文件(不進入其他文件系統),可以使用f i n d命令的m o u n t選項。
從當前目錄開始查找位於本文件系統中文件名以X C結尾的文件:
$ find . -name "*.XC" -mount -print


Linux其他查找文件的相關命令如下:

 more [文件名]

  分頁顯示一個文件或任何輸出結果

  其實more不是用來尋找文件的,但是一般人卻十有八九是在找文件時把它派上用場。

  因為 more 主要的作用是把輸出結果顯示在屏幕上,一頁停止一次,所以例如當我們用 ls 命令去找一個 x字母開頭的文件,而下達了 ls x* 卻仍然列出太多文件,一個屏幕看不完時,就可以配合管道符號和 more 命令:

  ls x* | more

  它會一屏停止一下,等待您按空白鍵才繼續往上卷。於是 more 儼然猶如 DOS 的 DIR 命令 /P 選項的地位了。而 more 當主角的時候,是用做一頁一次顯示文章,例如我們想要看 /etc 裡面的 XF86Config 文件,可以下如下命令:

  more /etc/XF86Config

  這樣,我們就可以不斷按空白鍵把這個文件慢慢看完。但是,因為more 先天的設計,如果您看完了這頁,想要回頭看上一頁,很抱歉,是不行的,您必須從頭再來!於是大家在使用中就乾脆摒棄這個命令,而代之以 vi 或者pico, joe等文書編輯器來看文字文件了!

  pico /etc/XF86Config

  到最後,很少人再用more了。所以more經常配合 ls在找文件的場合出現,每天都可以上場十幾次。

  所以,相信把失去主要舞台的 more歸類為找尋文件的相關命令雖不合法,但合情合理也合於現狀。

  練習:

  請您用 more 去看一個文字文件,與用 pico 去看一個文字文件相比較,哪一個比較方便?

 less [文件名]

  分頁顯示一個文件並且可以回頭

  less命令很好笑,取名時就故意與more 命令打對台,你叫"更多",我就叫"更少",就好像你叫黑人牙膏我就叫白人牙膏一樣。事實上與什麼"更多"、"更少"都沒有關係。它最主要只是為了改進一點:more 不能回頭看的問題!

  less 的優點就是可以隨時回頭,最簡單的用【PgUp】鍵就可以向上翻。

  可是依我們的孤陋之見,還是用文書編輯器去閱讀文件就好了嘛,更何況 less 本身還有高達 42 個選項,何必那麼麻煩!

  所以,為了您好,選項我們也不介紹了。這個命令目前只在 Linux 系統可以使用,其他 UNIX 家族尚無。

  練習:

  (1)請您用 less 去看一個文字文件,與用 pico 去看一個文字文件相比,哪一個比較方便?

  (2)less命令能像more命令一樣配合管道符號,讓ls的列示文件能夠回頭翻看嗎?

  whereis 文件名

  尋找文件工具

  whereis 是一個小巧好用的文件尋找工具,它專門用來尋找可執行的程序、原始程序和使用手冊。

  例如執行命令:

  whereis bzip2

  它就會告訴您,bzip2 放在 /usr/bin 。通常,如果您確定某個東西是程序,而用 whereis 找不到的話,那就表示本系統沒有安裝該程序了,例如:

  whereis cjoe

  表示這套系統中沒有裝 cjoe,否則應該會找到才對。

  練習:

  (1)找找您的系統上有沒有xpaint這個程序?因為這個程序在 KDE 和 GNOME 的默認主菜單上都沒有列出來,但並不表示一定沒有。

  (2)能用 whereis 命令去找到XF86Config設置文件在哪裡嗎?為什麼?

  locate 文件名

  尋找文件工具

  locate 也是一個尋找文件的工具,但是它不像 whereis 只能找程序文件等幾種文件,也不像find那麼複雜,可以算是"中庸之道"!

  中庸之道,往往就是大部分人最佳的選擇。


  whereis找不到的文件,find要一大串命令,還花了很久的時間才找到的XF86Config設置文件,而用locate一下子就簡單找到了!

  練習:

  (1)用 locate 找找有沒有一個inittab文件?

  (2)用 locate 找找有哪些 .pcf 字形文件。如果找不到的話,找找看已經壓縮過的字形文件 .pcf.Z 或者 .pcf.gz。

  grep [-選項] [字串] [文件名]

  尋找某字串內容工具

  有些時候,我們存儲文件時隨手亂取了一個文件名,事後自己都忘了那個文件名叫什麼,連開頭第一個字母都想不起來。那麼,如果您還記得該文件一點特殊的詞語,應該可以用 grep 命令找到。

  例如,我們想在一個目錄的200個文件裡面,找出哪一個文件提到"排版"這個詞語:

  grep 排版 *.txt

  找到了兩個文件有此字樣。然後您再自行調出看看到底哪一篇才是您所要的即可。尋找時注意盡量尋找特殊詞語,如果您輸入"然後"、"這樣"、"不是"、"電腦"……這類太普遍的詞語,可能幾百篇文章中都有,那就失去了用 grep 找文件的意義了。

  因為例子中第二篇文章出現了兩次,所以列出了3行,其實只有兩個文件符合。如果您想要讓它凡是符合條件的只出現一次的話,加上 -l 選項就可以了.

  其他常用的選項還有:

  -n 同時列出該詞語出現在文章的第幾行。

  -c 計算一下該字串出現的次數。

  -i 比對的時候,不計較大小寫的不同。

  練習:

  當我們要為系統增加一個用戶時,往往擔心添加一個已經存在的用戶名字。如果用 grep 命令,可不可以避免這個問題?如何避免?

 env

  查看環境設置

  env 命令可以設置很多環境變數,例如終端機的類型、使用的瀏覽器、用戶主目錄(Home Directory)的所在等等。

  但是我們現在把焦點集中在其中一項:PATH環境變數。

  因為 PATH 這個環境變數掌管了您下達命令的時候,它會到下面幾個目錄去找您命令的程序:

  /usr/bin

  /sbin

  /usr/sbin

  /usr/X11R6/bin

  /root/bin

  那麼您用 env 命令,讓它把所有的環境變數列出來的時候,就可以看到有一行PATH 設置,把上述幾個目錄用分號分開,然後串成一串。這就是它所謂尋找命令的"路徑"。DOS 系統也有一個同名而且意義非常相似的路徑設置。

  如果您想在它查找命令的路徑上增加一個 /usr/bin/he,而把 /root/bin 去掉,那麼您可以重新下達:

  env PATH=/usr/bin;/sbin;/usr/sbin;/usr/X11R6/bin;/usr/bin/he

  當然env 其他的變數也可以這樣改變。但是因為涉及面太廣,我們就只把焦點集中在改變查找路徑上,其他暫時不談。

  練習:

  用env命令改變您默認的瀏覽器。

[火星人 ] 《linux與unix shell編程》之Linux文件查找命令find,xargs詳述已經有690次圍觀

http://coctec.com/docs/linux/show-post-134952.html