新聞中心
grep是一個(gè)最初用于Unix操作系統(tǒng)的命令行工具。在給出文件列表或標(biāo)準(zhǔn)輸入后,grep會(huì)對(duì)匹配一個(gè)或多個(gè)正則表達(dá)式的文本進(jìn)行搜索,并只輸出匹配(或者不匹配)的行或文本。

創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站制作、成都做網(wǎng)站、科爾沁右翼前網(wǎng)絡(luò)推廣、成都微信小程序、科爾沁右翼前網(wǎng)絡(luò)營(yíng)銷(xiāo)、科爾沁右翼前企業(yè)策劃、科爾沁右翼前品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠(chéng)為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供科爾沁右翼前建站搭建服務(wù),24小時(shí)服務(wù)熱線:028-86922220,官方網(wǎng)址:www.cdcxhl.com
grep這個(gè)應(yīng)用程序最早由肯·湯普遜寫(xiě)成。grep原先是ed下的一個(gè)應(yīng)用程序,名稱來(lái)自于g/re/p(globally search a regular expression and print,以正規(guī)表示法進(jìn)行全局查找以及打?。?。
安裝 grep
Linux 默認(rèn)安裝了 grep。 MacOS 默認(rèn)安裝了 BSD 版的 grep。BSD 版的 grep 跟 GNU 版有一點(diǎn)不一樣,因此如果你想完全參照本文,那么請(qǐng)使用 Homebrew 或 MacPorts 安裝 GNU 版的 grep。
基礎(chǔ)的 grep
所有版本的 grep 基礎(chǔ)語(yǔ)法都一樣。入?yún)⑹瞧ヅ淠J胶湍阈枰阉鞯奈募?。它?huì)把匹配到的每一行輸出到你的終端。
$ grep gnu gpl-3.0.txt
along with this program. If not, see
.
.
. grep 命令默認(rèn)大小寫(xiě)敏感,因此 “gnu”、“GNU”、“Gnu” 是三個(gè)不同的值。你可以使用 --ignore-case 選項(xiàng)來(lái)忽略大小寫(xiě)。 $ grep --ignore-case gnu gpl-3.0.txt
你也可以通過(guò) –invert-match 選項(xiàng)來(lái)輸出所有沒(méi)有匹配到的行:
$ grep --invert-match \
--ignore-case gnu gpl-3.0.txt
Version 3, 29 June 2007
Copyright (C) 2007 Free Software Foundation, Inc.
[...648 lines...]
Public License instead of this License. But first, please read
管道
能搜索文件中的文本內(nèi)容是很有用的,但是 POSIX 的真正強(qiáng)大之處是可以通過(guò)“管道”來(lái)連接多條命令。我發(fā)現(xiàn)我使用 grep 最好的方式是把它與其他工具如 cut、tr 或 curl 聯(lián)合使用。 假如現(xiàn)在有一個(gè)文件,文件中每一行是我想要下載的技術(shù)論文。我可以打開(kāi)文件手動(dòng)點(diǎn)擊每一個(gè)鏈接,然后點(diǎn)擊火狐瀏覽器的選項(xiàng)把每一個(gè)文件保存到我的硬盤(pán),但是需要點(diǎn)擊多次且耗費(fèi)很長(zhǎng)時(shí)間。而我還可以搜索文件中的鏈接,用 –only-matching 選項(xiàng)只打印出匹配到的字符串。
$ grep --only-matching http\:\/\/.*pdf example.html
http://example.com/linux_whitepaper.pdf
http://example.com/bsd_whitepaper.pdf
http://example.com/important_security_topic.pdf
輸出是一系列的 URL,每行一個(gè)。而這與 Bash 處理數(shù)據(jù)的方式完美契合,因此我不再把 URL 打印到終端,而是把它們通過(guò)管道傳給 curl:
$ grep --only-matching http\:\/\/.*pdf \
example.html | curl --remote-name
這條命令可以下載每一個(gè)文件,然后以各自的遠(yuǎn)程文件名命名保存在我的硬盤(pán)上。 這個(gè)例子中我的搜索模式可能很晦澀。那是因?yàn)樗玫氖钦齽t表達(dá)式,一種在大量文本中進(jìn)行模糊搜索時(shí)非常有用的”通配符“語(yǔ)言。
正則表達(dá)式
沒(méi)有人會(huì)覺(jué)得正則表達(dá)式regular expression(簡(jiǎn)稱 “regex”)很簡(jiǎn)單。然而,我發(fā)現(xiàn)它的名聲往往比它應(yīng)得的要差。誠(chéng)然,很多人在使用正則表達(dá)式時(shí)“過(guò)于炫耀聰明”,直到它變得難以閱讀,大而全,以至于復(fù)雜得換行才好理解,但是你不必過(guò)度使用正則。這里簡(jiǎn)單介紹一下我使用正則表達(dá)式的方式。 首先,創(chuàng)建一個(gè)名為 example.txt 的文件,輸入以下內(nèi)容:
Albania
Algeria
Canada
0
1
3
11
最基礎(chǔ)的元素是不起眼的 . 字符。它表示一個(gè)字符。
$ grep Can.da example.txt
Canada
模式 Can.da 能成功匹配到 Canada 是因?yàn)?. 字符表示任意一個(gè)字符。 可以使用下面這些符號(hào)來(lái)使 . 通配符表示多個(gè)字符:
-
? 匹配前面的模式零次或一次
-
* 匹配前面的模式零次或多次
-
+ 匹配前面的模式一次或多次
-
{4} 匹配前面的模式 4 次(或是你在括號(hào)中寫(xiě)的其他次數(shù))
了解了這些知識(shí)后,你可以用你認(rèn)為有意思的所有模式來(lái)在 example.txt 中做練習(xí)??赡苡行?huì)成功,有些不會(huì)成功。重要的是你要去分析結(jié)果,這樣你才會(huì)知道原因。 例如,下面的命令匹配不到任何國(guó)家:
$ grep A.a example.txt
因?yàn)?. 字符只能匹配一個(gè)字符,除非你增加匹配次數(shù)。使用 * 字符,告訴 grep 匹配一個(gè)字符零次或者必要的任意多次直到單詞末尾。因?yàn)槟阒滥阋幚淼膬?nèi)容,因此在本例中零次是沒(méi)有必要的。在這個(gè)列表中一定沒(méi)有單個(gè)字母的國(guó)家。因此,你可以用 + 來(lái)匹配一個(gè)字符至少一次且任意多次直到單詞末尾:
$ grep A.+a example.txt
Albania
Algeria
你可以使用方括號(hào)來(lái)提供一系列的字母:
$ grep [A,C].+a example.txt
Albania
Algeria
Canada
也可以用來(lái)匹配數(shù)字。結(jié)果可能會(huì)震驚你:
$ grep [1-9] example.txt
1
3
11
看到 11 出現(xiàn)在搜索數(shù)字 1 到 9 的結(jié)果中,你驚訝嗎? 如果把 13 加到搜索列表中,會(huì)出現(xiàn)什么結(jié)果呢? 這些數(shù)字之所以會(huì)被匹配到,是因?yàn)樗鼈儼?1,而 1 在要匹配的數(shù)字中。 你可以發(fā)現(xiàn),正則表達(dá)式有時(shí)會(huì)令人費(fèi)解,但是通過(guò)體驗(yàn)和練習(xí),你可以熟練掌握它,用它來(lái)提高你搜索數(shù)據(jù)的能力。
下載備忘錄
grep 命令還有很多文章中沒(méi)有列出的選項(xiàng)。有用來(lái)更好地展示匹配結(jié)果、列出文件、列出匹配到的行號(hào)、通過(guò)打印匹配到的行周?chē)膬?nèi)容來(lái)顯示上下文的選項(xiàng),等等。如果你在學(xué)習(xí) grep,或者你經(jīng)常使用它并且通過(guò)查閱它的幫助頁(yè)面來(lái)查看選項(xiàng),那么你可以下載我們的備忘錄。這個(gè)備忘錄使用短選項(xiàng)(例如,使用 -v,而不是 –invert-matching)來(lái)幫助你更好地熟悉 grep。它還有一部分正則表達(dá)式可以幫你記住用途最廣的正則表達(dá)式代碼。
網(wǎng)頁(yè)題目:Linux的grep命令使用實(shí)例
文章出自:http://m.fisionsoft.com.cn/article/cdpejdi.html


咨詢
建站咨詢
