十年網(wǎng)站開(kāi)發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專業(yè)推廣+無(wú)憂售后,網(wǎng)站問(wèn)題一站解決
Linux常用指令---grep(搜索過(guò)濾) (轉(zhuǎn))
為上城等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及上城網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都網(wǎng)站制作、成都網(wǎng)站設(shè)計(jì)、上城網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!
Linux系統(tǒng)中g(shù)rep命令是一種強(qiáng)大的文本搜索工具,它能使用正則表達(dá)式搜索文本,并把匹?配的行打印出來(lái)。grep全稱是Global?Regular?Expression?Print,表示全局正則表達(dá)式版本,它的使用權(quán)限是所有用戶。
grep的工作方式是這樣的,它在一個(gè)或多個(gè)文件中搜索字符串模板。如果模板包括空格,則必須被引用,模板后的所有字符串被看作文件名。搜索的結(jié)果被送到標(biāo)準(zhǔn)輸出,不影響原文件內(nèi)容。
grep可用于shell腳本,因?yàn)間rep通過(guò)返回一個(gè)狀態(tài)值來(lái)說(shuō)明搜索的狀態(tài),如果模板搜索成功,則返回0,如果搜索不成功,則返回1,如果搜索的文件不存在,則返回2。我們利用這些返回值就可進(jìn)行一些自動(dòng)化的文本處理工作。
1.命令格式:
grep?[option]?pattern?file
2.命令功能:
用于過(guò)濾/搜索的特定字符??墒褂谜齽t表達(dá)式能多種命令配合使用,使用上十分靈活。
3.命令參數(shù):
-a???--text???#不要忽略二進(jìn)制的數(shù)據(jù)。???
-A顯示行數(shù)???--after-context=顯示行數(shù)???#除了顯示符合范本樣式的那一列之外,并顯示該行之后的內(nèi)容。???
-b???--byte-offset???#在顯示符合樣式的那一行之前,標(biāo)示出該行第一個(gè)字符的編號(hào)。???
-B顯示行數(shù)???--before-context=顯示行數(shù)???#除了顯示符合樣式的那一行之外,并顯示該行之前的內(nèi)容。???
-c????--count???#計(jì)算符合樣式的列數(shù)。???
-C顯示行數(shù)????--context=顯示行數(shù)或-顯示行數(shù)???#除了顯示符合樣式的那一行之外,并顯示該行之前后的內(nèi)容。???
-d?動(dòng)作??????--directories=動(dòng)作???#當(dāng)指定要查找的是目錄而非文件時(shí),必須使用這項(xiàng)參數(shù),否則grep指令將回報(bào)信息并停止動(dòng)作。???
-e范本樣式??--regexp=范本樣式???#指定字符串做為查找文件內(nèi)容的樣式。???
-E??????--extended-regexp???#將樣式為延伸的普通表示法來(lái)使用。???
-f規(guī)則文件??--file=規(guī)則文件???#指定規(guī)則文件,其內(nèi)容含有一個(gè)或多個(gè)規(guī)則樣式,讓grep查找符合規(guī)則條件的文件內(nèi)容,格式為每行一個(gè)規(guī)則樣式。???
-F???--fixed-regexp???#將樣式視為固定字符串的列表。???
-G???--basic-regexp???#將樣式視為普通的表示法來(lái)使用。???
-h???--no-filename???#在顯示符合樣式的那一行之前,不標(biāo)示該行所屬的文件名稱。???
-H???--with-filename???#在顯示符合樣式的那一行之前,表示該行所屬的文件名稱。???
-i????--ignore-case???#忽略字符大小寫(xiě)的差別。???
-l????--file-with-matches???#列出文件內(nèi)容符合指定的樣式的文件名稱。???
-L???--files-without-match???#列出文件內(nèi)容不符合指定的樣式的文件名稱。???
-n???--line-number???#在顯示符合樣式的那一行之前,標(biāo)示出該行的列數(shù)編號(hào)。???
-q???--quiet或--silent???#不顯示任何信息。???
-r???--recursive???#此參數(shù)的效果和指定“-d?recurse”參數(shù)相同。???
-s???--no-messages???#不顯示錯(cuò)誤信息。???
-v???--revert-match???#顯示不包含匹配文本的所有行。???
-V???--version???#顯示版本信息。???
-w???--word-regexp???#只顯示全字符合的列。???
-x????--line-regexp???#只顯示全列符合的列。???
-y???#此參數(shù)的效果和指定“-i”參數(shù)相同。
4.規(guī)則表達(dá)式:
grep的規(guī)則表達(dá)式:
^??#錨定行的開(kāi)始?如:'^grep'匹配所有以grep開(kāi)頭的行。????
$??#錨定行的結(jié)束?如:'grep$'匹配所有以grep結(jié)尾的行。????
.??#匹配一個(gè)非換行符的字符?如:'gr.p'匹配gr后接一個(gè)任意字符,然后是p。????
*??#匹配零個(gè)或多個(gè)先前字符?如:'*grep'匹配所有一個(gè)或多個(gè)空格后緊跟grep的行。????
.*???#一起用代表任意字符。???
[]???#匹配一個(gè)指定范圍內(nèi)的字符,如'[Gg]rep'匹配Grep和grep。????
[^]??#匹配一個(gè)不在指定范圍內(nèi)的字符,如:'[^A-FH-Z]rep'匹配不包含A-R和T-Z的一個(gè)字母開(kāi)頭,緊跟rep的行。????
\(..\)??#標(biāo)記匹配字符,如'\(love\)',love被標(biāo)記為1。????
\??????#錨定單詞的開(kāi)始,如:'\
\??????#錨定單詞的結(jié)束,如'grep\'匹配包含以grep結(jié)尾的單詞的行。????
x\{m\}??#重復(fù)字符x,m次,如:'0\{5\}'匹配包含5個(gè)o的行。????
x\{m,\}??#重復(fù)字符x,至少m次,如:'o\{5,\}'匹配至少有5個(gè)o的行。????
x\{m,n\}??#重復(fù)字符x,至少m次,不多于n次,如:'o\{5,10\}'匹配5--10個(gè)o的行。???
\w????#匹配文字和數(shù)字字符,也就是[A-Za-z0-9],如:'G\w*p'匹配以G后跟零個(gè)或多個(gè)文字或數(shù)字字符,然后是p。???
\W????#\w的反置形式,匹配一個(gè)或多個(gè)非單詞字符,如點(diǎn)號(hào)句號(hào)等。???
\b????#單詞鎖定符,如:?'\bgrep\b'只匹配grep。??
POSIX字符:
為了在不同國(guó)家的字符編碼中保持一至,POSIX(The?Portable?Operating?System?Interface)增加了特殊的字符類,如[:alnum:]是[A-Za-z0-9]的另一個(gè)寫(xiě)法。要把它們放到[]號(hào)內(nèi)才能成為正則表達(dá)式,如[A-?Za-z0-9]或[[:alnum:]]。在linux下的grep除fgrep外,都支持POSIX的字符類。
[:alnum:]????#文字?jǐn)?shù)字字符???
[:alpha:]????#文字字符???
[:digit:]????#數(shù)字字符???
[:graph:]????#非空字符(非空格、控制字符)???
[:lower:]????#小寫(xiě)字符???
[:cntrl:]????#控制字符???
[:print:]????#非空字符(包括空格)???
[:punct:]????#標(biāo)點(diǎn)符號(hào)???
[:space:]????#所有空白字符(新行,空格,制表符)???
[:upper:]????#大寫(xiě)字符???
[:xdigit:]???#十六進(jìn)制數(shù)字(0-9,a-f,A-F)??
5.使用實(shí)例:
實(shí)例1:查找指定進(jìn)程
命令:
ps?-ef|grep?svn
輸出:
[root@localhost?~]#?ps?-ef|grep?svn
root?4943???1??????0??Dec05?????00:00:00?svnserve?-d?-r?/opt/svndata/grape/
root?16867?16838??0?19:53?pts/0????00:00:00?grep?svn
[root@localhost?~]#
說(shuō)明:
第一條記錄是查找出的進(jìn)程;第二條結(jié)果是grep進(jìn)程本身,并非真正要找的進(jìn)程。
實(shí)例2:查找指定進(jìn)程個(gè)數(shù)
命令:
ps?-ef|grep?svn?-c
ps?-ef|grep?-c?svn
輸出:
[root@localhost?~]#?ps?-ef|grep?svn?-c
2
[root@localhost?~]#?ps?-ef|grep?-c?svn?
2
[root@localhost?~]#
說(shuō)明:
實(shí)例3:從文件中讀取關(guān)鍵詞進(jìn)行搜索
命令:
cat?test.txt?|?grep?-f?test2.txt
輸出:
[root@localhost?test]#?cat?test.txt?
hnlinux
peida.cnblogs.com
ubuntu
ubuntu?linux
redhat
Redhat
linuxmint
[root@localhost?test]#?cat?test2.txt?
linux
Redhat
[root@localhost?test]#?cat?test.txt?|?grep?-f?test2.txt
hnlinux
ubuntu?linux
Redhat
linuxmint
[root@localhost?test]#
說(shuō)明:
輸出test.txt文件中含有從test2.txt文件中讀取出的關(guān)鍵詞的內(nèi)容行
實(shí)例3:從文件中讀取關(guān)鍵詞進(jìn)行搜索?且顯示行號(hào)
命令:
cat?test.txt?|?grep?-nf?test2.txt
輸出:
[root@localhost?test]#?cat?test.txt?
hnlinux
peida.cnblogs.com
ubuntu
ubuntu?linux
redhat
Redhat
linuxmint
[root@localhost?test]#?cat?test2.txt?
linux
Redhat
[root@localhost?test]#?cat?test.txt?|?grep?-nf?test2.txt
1:hnlinux
4:ubuntu?linux
6:Redhat
7:linuxmint
[root@localhost?test]#
說(shuō)明:
輸出test.txt文件中含有從test2.txt文件中讀取出的關(guān)鍵詞的內(nèi)容行,并顯示每一行的行號(hào)
實(shí)例5:從文件中查找關(guān)鍵詞
命令:
grep?'linux'?test.txt
輸出:
[root@localhost?test]#?grep?'linux'?test.txt?
hnlinux
ubuntu?linux
linuxmint
[root@localhost?test]#?grep?-n?'linux'?test.txt?
1:hnlinux
4:ubuntu?linux
7:linuxmint
[root@localhost?test]#
說(shuō)明:
實(shí)例6:從多個(gè)文件中查找關(guān)鍵詞
命令:
grep?'linux'?test.txt?test2.txt
輸出:
[root@localhost?test]#?grep?-n?'linux'?test.txt?test2.txt?
test.txt:1:hnlinux
test.txt:4:ubuntu?linux
test.txt:7:linuxmint
test2.txt:1:linux
[root@localhost?test]#?grep?'linux'?test.txt?test2.txt?
test.txt:hnlinux
test.txt:ubuntu?linux
test.txt:linuxmint
test2.txt:linux
[root@localhost?test]#
說(shuō)明:
多文件時(shí),輸出查詢到的信息內(nèi)容行時(shí),會(huì)把文件的命名在行最前面輸出并且加上":"作為標(biāo)示符
實(shí)例7:grep不顯示本身進(jìn)程
命令:
ps?aux|grep?\[s]sh
ps?aux?|?grep?ssh?|?grep?-v?"grep"
輸出:
[root@localhost?test]#?ps?aux|grep?ssh
root???2720??0.0??0.0??62656??1212????????Ss???Nov02???0:00?/usr/sbin/sshd
root??16834??0.0??0.0??88088??3288????????Ss???19:53???0:00?sshd:?root@pts/0?
root??16901??0.0??0.0??61180???764?pts/0??S+???20:31???0:00?grep?ssh
[root@localhost?test]#?ps?aux|grep?\[s]sh]
[root@localhost?test]#?ps?aux|grep?\[s]sh
root???2720??0.0??0.0??62656??1212????????Ss???Nov02???0:00?/usr/sbin/sshd
root??16834??0.0??0.0??88088??3288????????Ss???19:53???0:00?sshd:?root@pts/0?
[root@localhost?test]#?ps?aux?|?grep?ssh?|?grep?-v?"grep"
root???2720??0.0??0.0??62656??1212????????Ss???Nov02???0:00?/usr/sbin/sshd
root??16834??0.0??0.0??88088??3288????????Ss???19:53???0:00?sshd:?root@pts/0
說(shuō)明:
實(shí)例8:找出已u開(kāi)頭的行內(nèi)容
命令:
cat?test.txt?|grep?^u
輸出:
[root@localhost?test]#?cat?test.txt?|grep?^u
ubuntu
ubuntu?linux
[root@localhost?test]#
說(shuō)明:
實(shí)例9:輸出非u開(kāi)頭的行內(nèi)容
命令:
cat?test.txt?|grep?^[^u]
輸出:
[root@localhost?test]#?cat?test.txt?|grep?^[^u]
hnlinux
peida.cnblogs.com
redhat
Redhat
linuxmint
[root@localhost?test]#
說(shuō)明:
實(shí)例10:輸出以hat結(jié)尾的行內(nèi)容
命令:
cat?test.txt?|grep?hat$
輸出:
[root@localhost?test]#?cat?test.txt?|grep?hat$
redhat
Redhat
[root@localhost?test]#
說(shuō)明:
實(shí)例11:輸出ip地址
命令:
ifconfig?eth0|grep?-E?"([0-9]{1,3}\.){3}[0-9]"
輸出:
[root@localhost?test]#?ifconfig?eth0|grep?"[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}"
inet?addr:192.168.120.204??Bcast:192.168.120.255??Mask:255.255.255.0
[root@localhost?test]#?ifconfig?eth0|grep?-E?"([0-9]{1,3}\.){3}[0-9]"
inet?addr:192.168.120.204??Bcast:192.168.120.255??Mask:255.255.255.0
[root@localhost?test]#
說(shuō)明:
實(shí)例12:顯示包含ed或者at字符的內(nèi)容行
命令:
cat?test.txt?|grep?-E?"ed|at"
輸出:
[root@localhost?test]#?cat?test.txt?|grep?-E?"peida|com"
peida.cnblogs.com
[root@localhost?test]#?cat?test.txt?|grep?-E?"ed|at"
redhat
Redhat
[root@localhost?test]#
說(shuō)明:
實(shí)例13:顯示當(dāng)前目錄下面以.txt?結(jié)尾的文件中的所有包含每個(gè)字符串至少有7個(gè)連續(xù)小寫(xiě)字符的字符串的行
命令:
grep?'[a-z]\{7\}'?*.txt
輸出:
[root@localhost?test]#?grep?'[a-z]\{7\}'?*.txt
test.txt:hnlinux
test.txt:peida.cnblogs.com
test.txt:linuxmint
[root@localhost?test]#
實(shí)例14:日志文件過(guò)大,不好查看,我們要從中查看自己想要的內(nèi)容,或者得到同一類數(shù)據(jù),比如說(shuō)沒(méi)有404日志信息的
命令:
grep?'.'?access1.log|grep?-Ev?'404'??access2.log
grep?'.'?access1.log|grep?-Ev?'(404|/photo/|/css/)'??access2.log
grep?'.'?access1.log|grep?-E?'404'??access2.log
輸出:
[root@localhost?test]#?grep?“.”access1.log|grep?-Ev?“404”??access2.log
說(shuō)明:上面3句命令前面兩句是在當(dāng)前目錄下對(duì)access1.log文件進(jìn)行查找,找到那些不包含404的行,把它們放到access2.log中,后面去掉’v’,即是把有404的行放入access2.log
find / -name 文件名\x0d\x0a\x0d\x0aLinux下find命令用法\x0d\x0a\x0d\x0a通過(guò)文件名查找法: \x0d\x0a這個(gè)方法說(shuō)起來(lái)就和在WINDOWS下查找文件一樣容易理解了。如果你把這個(gè)文件放在單個(gè)的文件夾里面,只要使用常見(jiàn)的“l(fā)s"命令就能方便的查找出來(lái),那么使用“find”命令來(lái)查找它就不能給你留下深刻的印象,畢竟“find”命令的強(qiáng)大功能不止這 個(gè)。如果知道了某個(gè)文件的文件名,而不知道這個(gè)文件放到哪個(gè)文件夾,甚至是層層套嵌的文件夾里。舉例說(shuō)明,假設(shè)你忘記了httpd.conf這個(gè)文件在系統(tǒng)的哪個(gè)目錄下,甚至在系統(tǒng)的某個(gè)地方也不知道,則這是可以使用如下命令: \x0d\x0afind / -name httpd.conf \x0d\x0a\x0d\x0a這個(gè)命令語(yǔ)法看起來(lái)很容易就明白了,就是直接在find后面寫(xiě)上 -name,表明要求系統(tǒng)按照文件名查找,最后寫(xiě)上httpd.conf這個(gè)目標(biāo)文件名即可。稍等一會(huì)系統(tǒng)會(huì)在計(jì)算機(jī)屏幕上顯示出查找結(jié)果列表: \x0d\x0aetc/httpd/conf/httpd.conf \x0d\x0a\x0d\x0a這就是httpd.conf這個(gè)文件在Linux系統(tǒng)中的完整路徑。查找成功。 \x0d\x0a如果輸入以上查找命令后系統(tǒng)并沒(méi)有顯示出結(jié) 果,那么不要以為系統(tǒng)沒(méi)有執(zhí)行find/ -name httpd.conf命令,而可能是你的系統(tǒng)中沒(méi)有安裝Apache服務(wù)器,這時(shí)只要你安裝了Apache Web服務(wù)器,然后再使用find / -name httpd.conf就能找到這個(gè)配置文件了。 \x0d\x0a\x0d\x0a無(wú)錯(cuò)誤查找技巧: \x0d\x0a在Linux系統(tǒng)中“find”命令是大多數(shù)系統(tǒng)用戶都可以使用的命令,并不是ROOT系統(tǒng)管理員的專利。但是普通用戶使用“find”命令時(shí)也有可能遇到這樣的問(wèn)題,那就是Linux系統(tǒng)中系統(tǒng)管理員ROOT可以把某些文件目錄設(shè)置成禁止訪問(wèn)模式。這樣普通用戶就沒(méi)有權(quán)限用“find”命令來(lái)查詢這些目錄或者文件。當(dāng)普通用戶使用“find”命令來(lái) 查詢這些文件目錄是,往往會(huì)出現(xiàn)"Permissiondenied."(禁止訪問(wèn))字樣。系統(tǒng)將無(wú)法查詢到你想要的文件。為了避免這樣的錯(cuò)誤,我們可是使用轉(zhuǎn)移錯(cuò)誤提示的方法嘗試著查找文件,輸入 \x0d\x0afind / -name access_log 2/dev/null \x0d\x0a\x0d\x0a這個(gè)方法是把查找錯(cuò)誤提示轉(zhuǎn)移到特定的目錄中去。系統(tǒng)執(zhí)行這個(gè)命令后,遇到錯(cuò)誤的信息就直接輸送到stderrstream 2 中,access_log 2就是表明系統(tǒng)將把錯(cuò)誤信息輸送到stderrstream 2中,/dev/null是一個(gè)特殊的文件,表明空的或者錯(cuò)誤的信息,這樣查詢到的錯(cuò)誤信息將被轉(zhuǎn)移了,不會(huì)再顯示了。 \x0d\x0a\x0d\x0a在Linux系統(tǒng)查找文件也會(huì)遇到這樣一個(gè)實(shí)際問(wèn)題。如果我們?cè)谡麄€(gè)硬盤(pán),這個(gè)系統(tǒng)中查找某個(gè)文件就要花費(fèi)相當(dāng)長(zhǎng)的一段時(shí)間,特別是大型Linux系統(tǒng)和容量較大的硬 盤(pán),文件放在套嵌很深的目錄中的時(shí)候。如果我們知道了這個(gè)文件存放在某個(gè)大的目錄中,那么只要在這個(gè)目錄中往下找就能節(jié)省很多時(shí)間了。使用find /etc -name httpd.conf 就可以解決這個(gè)問(wèn)題。上面的命令就是表示在etc目錄中查詢httpd.conf這個(gè)文件。這里再說(shuō)明一下“/ ”這個(gè)函數(shù)符號(hào)的含義,如果輸入 “find/ ”就是表示要求Linux系統(tǒng)在整個(gè)ROOT目錄下查找文件,也就是在整個(gè)硬盤(pán)上查找文件,而“find/etc”就是只在 etc目錄下查找文件。因?yàn)椤癴ind/etc”表示只在etc目錄下查找文件,所以查找的速度就相應(yīng)要快很多了。 \x0d\x0a\x0d\x0a根據(jù)部分文件名查找方法: \x0d\x0a這個(gè)方法和在WINDOWS中查找已知的文件名方法是一樣的。不過(guò)在Linux中根據(jù)部分文件名查找文件的方法要比在WINDOWS中的同類查找方法要強(qiáng)大得多。例如我們知道某個(gè)文件包含有srm這3個(gè)字母,那么要找到系統(tǒng)中所有包含有這3個(gè)字母的文件是可以實(shí)現(xiàn)的,輸入: \x0d\x0afind /etc -name '*srm*' \x0d\x0a\x0d\x0a這個(gè)命令表明了Linux系統(tǒng)將在/etc整個(gè)目錄中查找所有的包含有srm這3個(gè)字母的文 件,比如 absrmyz, tibc.srm等等符合條件的文件都能顯示出來(lái)。如果你還知道這個(gè)文件是由srm 這3個(gè)字母打頭的,那么我們還可以省略最前面的星號(hào),命令如下: \x0d\x0afind/etc -name 'srm*' \x0d\x0a\x0d\x0a這是只有像 srmyz 這樣的文件才被查找出來(lái),象absrmyz或者 absrm這樣的文件都不符合要求,不被顯示,這樣查找文件的效率和可靠性就大大增強(qiáng)了。 \x0d\x0a\x0d\x0a根據(jù)文件的特征查詢方法: \x0d\x0a如果只知道某個(gè)文件的大小,修改日期等特征也可以使用“find”命令查找出來(lái),這和WINDOWS系統(tǒng)中的"搜索"功 能是基本相同的。在微軟的"搜索"中WINDOWS中的"搜索助理"使得搜索文件和文件夾、打印機(jī)、用戶以及網(wǎng)絡(luò)中的其他計(jì)算機(jī)更加容易。它甚至使在 Internet 上搜索更加容易。"搜索助理"還包括一個(gè)索引服務(wù),該服務(wù)維護(hù)了計(jì)算機(jī)中所有文件的索引,使得搜索速度更快。使用"搜索助理"時(shí),用戶可以指定多個(gè)搜索標(biāo) 準(zhǔn)。例如,用戶可以按名稱、類型及大小搜索文件和文件夾。用戶甚至可以搜索包含特定文本的文件。如果用戶正使用 Active Directory,這時(shí)還可以搜索帶有特定名稱或位置的打印機(jī)。 \x0d\x0a\x0d\x0a例如我們知道一個(gè)Linux文件大小為1,500 bytes,那么我們可是使用如下命令來(lái)查詢find / -size 1500c,字符 c 表明這個(gè)要查找的文件的大小是以bytes為單位。如果我們連這個(gè)文件的具體大小都不知道,那么在Linux中還可以進(jìn)行模糊查找方式來(lái)解決。例如我們輸 入find/ -size +10000000c 這個(gè)命令,則標(biāo)明我們指定系統(tǒng)在根目錄中查找出大于10000000字節(jié)的文件并顯示出來(lái)。命令中的“+”是表示要求系統(tǒng)只列出大于指定大小的文件,而使 用“-”則表示要求系統(tǒng)列出小于指定大小的文件。下面的列表就是在Linux使用不同“ find"命令后系統(tǒng)所要作出的查找動(dòng)作,從中我們很容易看出在Linux中使用“find"命令的方式是很多的,“ find"命令查找文件只要靈活應(yīng)用,絲毫不必在WINDOWS中查找能力差。 \x0d\x0a\x0d\x0afind / -amin -10 # 查找在系統(tǒng)中最后10分鐘訪問(wèn)的文件 \x0d\x0afind / -atime -2 # 查找在系統(tǒng)中最后48小時(shí)訪問(wèn)的文件 \x0d\x0afind / -empty # 查找在系統(tǒng)中為空的文件或者文件夾 \x0d\x0afind / -group cat # 查找在系統(tǒng)中屬于 groupcat的文件 \x0d\x0afind / -mmin -5 # 查找在系統(tǒng)中最后5分鐘里修改過(guò)的文件 \x0d\x0afind / -mtime -1 #查找在系統(tǒng)中最后24小時(shí)里修改過(guò)的文件 \x0d\x0afind / -nouser #查找在系統(tǒng)中屬于作廢用戶的文件 \x0d\x0afind / -user fred #查找在系統(tǒng)中屬于FRED這個(gè)用戶的文件 \x0d\x0a\x0d\x0a下面的列表就是對(duì)find命令所可以指定文件的特征進(jìn)行查找的部分條件。在這里并沒(méi)有列舉所有的查找條件,參考有關(guān)Linux有關(guān)書(shū)籍可以知道所有find命令的查找函數(shù)。 \x0d\x0a\x0d\x0a-amin n \x0d\x0a查找系統(tǒng)中最后N分鐘訪問(wèn)的文件 \x0d\x0a-atime n \x0d\x0a查找系統(tǒng)中最后n*24小時(shí)訪問(wèn)的文件 \x0d\x0a-cmin n \x0d\x0a查找系統(tǒng)中最后N分鐘被改變狀態(tài)的文件 \x0d\x0a-ctime n \x0d\x0a查找系統(tǒng)中最后n*24小時(shí)被改變狀態(tài)的文件 \x0d\x0a-empty \x0d\x0a查找系統(tǒng)中 空白的文件,或空白的文件目錄,或目錄中沒(méi)有子目錄的文件夾 \x0d\x0a-false \x0d\x0a查找系統(tǒng)中總是錯(cuò)誤的文件 \x0d\x0a-fstype type\x0d\x0a查找系統(tǒng)中存在于指定文件系統(tǒng)的文件,例如:ext2 . \x0d\x0a-gid n \x0d\x0a查找系統(tǒng)中文件數(shù)字組 ID 為 n的文件 \x0d\x0a-group gname \x0d\x0a查找系統(tǒng)中文件屬于gnam文件組,并且指定組和ID的文件 \x0d\x0a\x0d\x0aFind命令的控制選項(xiàng)說(shuō)明: \x0d\x0a\x0d\x0aFind 命令也提供給用戶一些特有的選項(xiàng)來(lái)控制查找操作。下表就是我們總結(jié)出的最基本,最常用的find命令的控制選項(xiàng)及其用法。 \x0d\x0a\x0d\x0a 選項(xiàng) 用途描 述 \x0d\x0a-daystart 測(cè)試系統(tǒng)從今天開(kāi)始24小時(shí)以內(nèi)的文件,用法類似-amin \x0d\x0a-depth 使用深度級(jí)別的 查找過(guò)程方式,在某層指定目錄中優(yōu)先查找文件內(nèi)容 \x0d\x0a-follow 遵循通配符鏈接方式查找; 另外,也可忽略通配符鏈接方式查詢 \x0d\x0a-help 顯示命令摘要 \x0d\x0a-maxdepth levels 在某個(gè)層次的目錄中按照遞減方法查找 \x0d\x0a-mount 不在文件系統(tǒng)目錄中查找,用法類似 -xdev. \x0d\x0a-noleaf 禁止在非UNUX文件系統(tǒng),MS-DOS系統(tǒng),CD-ROM文件系統(tǒng)中 進(jìn)行最優(yōu)化查找 \x0d\x0a-version 打印版本數(shù)字 \x0d\x0a\x0d\x0a使用-follow選項(xiàng)后,find命令則遵循通配符鏈接方式進(jìn)行查找,除非你指定這個(gè)選項(xiàng),否則一般情況下find命令將忽略通配符鏈接方式進(jìn)行文件查找。 \x0d\x0a\x0d\x0a-maxdepth選項(xiàng)的作用就是限制find命令在目錄中按照遞減方式查找文件的時(shí)候搜索文件超過(guò)某個(gè)級(jí)別或者搜索過(guò)多的目錄,這樣導(dǎo)致查找速度變慢,查找花費(fèi)的時(shí)間過(guò)多。例如,我們要在當(dāng)前(.)目錄的子目錄中查找一個(gè)名叫fred的文件,我們可以使用如下命令 \x0d\x0afind . -maxdepth 2 -name fred \x0d\x0a\x0d\x0a假如這個(gè)fred文件在./sub1/fred目錄中,那么這個(gè)命令就會(huì)直接定位這個(gè)文件,查找很容易成功。假如,這個(gè)文件在./sub1/sub2 /fred目錄中,那么這個(gè)命令就無(wú)法查找到。因?yàn)榍懊嬉呀?jīng)給find命令在目錄中最大的查詢目錄級(jí)別為2,只能查找2層目錄下的文件。這樣做的目的就是 為了讓find命令更加精確的定位文件,如果你已經(jīng)知道了某個(gè)文件大概所在的文件目錄級(jí)數(shù),那么加入-maxdepth n 就很快的能在指定目錄中查找成功。 \x0d\x0a\x0d\x0a使用混合查找方式查找文件 \x0d\x0afind命令可以使用混合查找的方法,例如我們想在/tmp目錄 中查找大于100000000字節(jié)并且在48小時(shí)內(nèi)修改的某個(gè)文件,我們可以使用-and 來(lái)把兩個(gè)查找選項(xiàng)鏈接起來(lái)組合成一個(gè)混合的查找方式。 \x0d\x0afind /tmp -size +10000000c -and -mtime +2 \x0d\x0a\x0d\x0a學(xué)習(xí)過(guò)計(jì)算機(jī)語(yǔ)言的朋友都知道,在計(jì)算機(jī)語(yǔ)言里,使用 and ,or 分別表示“與”和“或”的關(guān)系。在Linux系統(tǒng)的查找命令中一樣通用。 \x0d\x0a還有這樣的例子, \x0d\x0afind / -user fred -or -user george \x0d\x0a\x0d\x0a我們可以解釋為在/tmp目錄中查找屬于fred或者george這兩個(gè)用戶的文件。 \x0d\x0a在 find命令中還可以使用“非”的關(guān)系來(lái)查找文件,如果我們要在/tmp目錄中查找所有不屬于panda的文件,使用一個(gè)簡(jiǎn)單的 \x0d\x0afind /tmp ! -user panda \x0d\x0a命令就可以解決了。很簡(jiǎn)單。 \x0d\x0a\x0d\x0a查找并顯示文件的方法 \x0d\x0a查找到某個(gè)文件是我們的目 的,我們更想知道查找到的文件的詳細(xì)信息和屬性,如果我們采取現(xiàn)查找文件,再使用ls命令來(lái)查看文件信息是相當(dāng)繁瑣的,現(xiàn)在我們也可以把這兩個(gè)命令結(jié)合起來(lái)使用。 \x0d\x0afind / -name "httpd.conf" -ls \x0d\x0a\x0d\x0a系統(tǒng)查找到httpd.conf文件后立即在屏幕上顯 示httpd.conf文件信息。 \x0d\x0a12063 34 -rw-r--r-- 1 root root 33545 Dec 30 15:36 /etc/httpd/conf/httpd.conf \x0d\x0a\x0d\x0a下面的表格就是一些常用的查找文件并顯示文件信息的參數(shù)和使用方法 \x0d\x0a\x0d\x0a選 項(xiàng) 用途描述 \x0d\x0a-exec command; 查找并執(zhí)行命令 \x0d\x0a-fprint file 打印文件完整文件名 \x0d\x0a-fprint0 file 打印文件完整文件名包括空的文件 \x0d\x0a-fprintf file format 打印文件格式 \x0d\x0a-ok command; 給用戶命令執(zhí)行操作,根據(jù)用戶的Y 確認(rèn)輸入執(zhí)行 \x0d\x0a-printf format 打印文件格式 \x0d\x0a-ls 打印同種文件格式的文件. \x0d\x0a\x0d\x0a總結(jié):到這里為止我們已經(jīng)學(xué)習(xí)了這名多關(guān)于find命令的使用 方法,也列出了很多常用的find命令的選項(xiàng),如果我們能熟練掌握在Linux中find命令的使用方法,那么在Linux中查找文件也不是一件困難的事 情。
1、打開(kāi)shell連接工具,連接上服務(wù)器,pwd查看當(dāng)前目錄,一般進(jìn)來(lái)默認(rèn)在主目錄下。
2、通過(guò)命令:cd /切換到主目錄下,然后pwd查看當(dāng)前目錄,并用ls可以查看當(dāng)前目錄下的文件及目錄。
3、假如要找一個(gè)nginx配置文件nginx.conf,那么可以通過(guò)find命令查找:find . -name 'nginx.conf'。
4、假如不知道文件的具體名字只是模糊記得幾個(gè)關(guān)鍵的單詞,那么就可以通過(guò)模糊匹配去搜索:find 目錄 -name '*nginx*' 查找即可。
題主你好,
解題思路:?使用-type?d指定我們要查找的是文件夾,?而不是文件啥的;?再就是使用通佩符來(lái)匹配中間是data的名稱: -name "*data*"
命令如下:
find?/?-type?d?-name?"*data*"
-----
上面命令是從根目錄開(kāi)始找的, 下面給題主舉個(gè)例子,在當(dāng)前目錄下查找中間是data的文件夾:
從上圖可以看出,當(dāng)前文件夾中adatab是文件夾, cdatad是文件,按照上面說(shuō)的規(guī)則,最終查找的結(jié)果只有adatab,說(shuō)明是正確的, 因?yàn)閏datad雖然也符合名稱的規(guī)則,但它的類型是文件而非文件夾,因此結(jié)果不包含cdatad.
希望可以幫到題主,?歡迎追問(wèn)