91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Linux的grep命令如何使用

發布時間:2022-02-11 09:44:34 來源:億速云 閱讀:189 作者:iii 欄目:開發技術

這篇文章主要講解了“Linux的grep命令如何使用”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Linux的grep命令如何使用”吧!

grep是一個最初用于Unix操作系統的命令行工具。在給出文件列表或標準輸入后,grep會對匹配一個或多個正則表達式的文本進行搜索,并只輸出匹配(或者不匹配)的行或文本。grep這個應用程序最早由肯·湯普遜寫成。grep原先是ed下的一個應用程序,名稱來自于g/re/p(globally search a regular expression and print,以正規表示法進行全局查找以及打印)。

Linux的grep命令如何使用

安裝 grep

Linux 默認安裝了 grep。 MacOS 默認安裝了 BSD 版的 grep。BSD 版的 grep 跟 GNU 版有一點不一樣,因此如果你想完全參照本文,那么請使用 Homebrew 或 MacPorts 安裝 GNU 版的 grep。

基礎的 grep

所有版本的 grep 基礎語法都一樣。入參是匹配模式和你需要搜索的文件。它會把匹配到的每一行輸出到你的終端。

$ grep gnu gpl-3.0.txt
along with this program. If not, see ...
grep 命令默認大小寫敏感,因此 “gnu”、“GNU”、“Gnu” 是三個不同的值。你可以使用 --ignore-case 選項來忽略大小寫。
$ grep --ignore-case gnu gpl-3.0.txt

你也可以通過 –invert-match 選項來輸出所有沒有匹配到的行:

$ 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

管道

能搜索文件中的文本內容是很有用的,但是 POSIX 的真正強大之處是可以通過“管道”來連接多條命令。我發現我使用 grep 最好的方式是把它與其他工具如 cut、tr 或 curl 聯合使用。 假如現在有一個文件,文件中每一行是我想要下載的技術論文。我可以打開文件手動點擊每一個鏈接,然后點擊火狐瀏覽器的選項把每一個文件保存到我的硬盤,但是需要點擊多次且耗費很長時間。而我還可以搜索文件中的鏈接,用 –only-matching 選項只打印出匹配到的字符串。

$ 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,每行一個。而這與 Bash 處理數據的方式完美契合,因此我不再把 URL 打印到終端,而是把它們通過管道傳給 curl:

$ grep --only-matching http\:\/\/.*pdf \
example.html | curl --remote-name

這條命令可以下載每一個文件,然后以各自的遠程文件名命名保存在我的硬盤上。 這個例子中我的搜索模式可能很晦澀。那是因為它用的是正則表達式,一種在大量文本中進行模糊搜索時非常有用的”通配符“語言。

正則表達式

沒有人會覺得正則表達式regular expression(簡稱 “regex”)很簡單。然而,我發現它的名聲往往比它應得的要差。誠然,很多人在使用正則表達式時“過于炫耀聰明”,直到它變得難以閱讀,大而全,以至于復雜得換行才好理解,但是你不必過度使用正則。這里簡單介紹一下我使用正則表達式的方式。 首先,創建一個名為 example.txt 的文件,輸入以下內容:

Albania
Algeria
Canada
0
1
3
11

最基礎的元素是不起眼的 . 字符。它表示一個字符。

$ grep Can.da example.txt

Canada

模式 Can.da 能成功匹配到 Canada 是因為 . 字符表示任意一個字符。 可以使用下面這些符號來使 . 通配符表示多個字符:

  1. ? 匹配前面的模式零次或一次
  2. * 匹配前面的模式零次或多次
  3. + 匹配前面的模式一次或多次
  4. {4} 匹配前面的模式 4 次(或是你在括號中寫的其他次數)

了解了這些知識后,你可以用你認為有意思的所有模式來在 example.txt 中做練習。可能有些會成功,有些不會成功。重要的是你要去分析結果,這樣你才會知道原因。 例如,下面的命令匹配不到任何國家:

$ grep A.a example.txt

因為 . 字符只能匹配一個字符,除非你增加匹配次數。使用 * 字符,告訴 grep 匹配一個字符零次或者必要的任意多次直到單詞末尾。因為你知道你要處理的內容,因此在本例中零次是沒有必要的。在這個列表中一定沒有單個字母的國家。因此,你可以用 + 來匹配一個字符至少一次且任意多次直到單詞末尾:

$ grep A.+a example.txt
Albania
Algeria

你可以使用方括號來提供一系列的字母:

$ grep [A,C].+a example.txt
Albania
Algeria
Canada

也可以用來匹配數字。結果可能會震驚你:

$ grep [1-9] example.txt
1
3
11

看到 11 出現在搜索數字 1 到 9 的結果中,你驚訝嗎? 如果把 13 加到搜索列表中,會出現什么結果呢? 這些數字之所以會被匹配到,是因為它們包含 1,而 1 在要匹配的數字中。 你可以發現,正則表達式有時會令人費解,但是通過體驗和練習,你可以熟練掌握它,用它來提高你搜索數據的能力。

感謝各位的閱讀,以上就是“Linux的grep命令如何使用”的內容了,經過本文的學習后,相信大家對Linux的grep命令如何使用這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

原阳县| 佛坪县| 金山区| 临沭县| 蒙山县| 宜都市| 吴桥县| 佛坪县| 景谷| 黄石市| 旬邑县| 宜昌市| 蓬溪县| 大名县| 周宁县| 梁山县| 曲松县| 定西市| 山阳县| 从江县| 石泉县| 湘阴县| 新津县| 犍为县| 资溪县| 高碑店市| 花莲市| 铜梁县| 乐清市| 鄂托克旗| 香河县| 宝兴县| 洪洞县| 蒙自县| 武夷山市| 青浦区| 马山县| 新闻| 新邵县| 综艺| 庄河市|