我們一起來玩轉 Grep 指令
導讀 | grep這個 指令大家一定不陌生,其用於查詢檔案中符合條件的字串,下面來看看這個高頻的指令如何使用。 |
在一個陽光明媚、晴空萬里的中午,一個撓頭的程式設計師正在與團隊一姐排查超時問題,只見一姐手速極快的查詢著一個又一個日誌,快速定位到一個又一個嫌疑人,仰慕之情油然而生,為了後續也能夠在小迷妹手上秀技術,所以暗下決心準備學習這個牛逼的東西。下面有請今天的主角(grep指令)閃亮登場。
grep這個linux指令大家一定不陌生,其用於查詢檔案中符合條件的字串,下面來看看這個高頻的指令如何使用。
grep [選項] 查詢內容 [原始檔]
觀察其組成結構,由四部分組成:指令名(grep)、選項、查詢內容、原始檔,其中需要注意的有兩個位置,下面讓我們徐徐道來。
原始檔部分是可有可無的,若不指定任何檔名稱或是所給予的檔名為-,則grep指令會從標準輸入裝置讀取資料,其使用如下所示:
// 檔案路徑為/test // 接收cat的輸入 cat ./test |grep 'hello' // 存在路徑部分引數 grep 'hello' ./test
選項部分比較多,可以透過grep --help指令來看一下有哪些選項:
Regexp selection and interpretation: // 正規表示式選擇和解釋 -E, --extended-regexp PATTERN is an extended regular expression (ERE) -F, --fixed-strings PATTERN is a set of newline-separated strings -G, --basic-regexp PATTERN is a basic regular expression (BRE) -P, --perl-regexp PATTERN is a Perl regular expression -e, --regexp=PATTERN use PATTERN for matching -f, --file=FILE obtain PATTERN from FILE -i, --ignore-case ignore case distinctions -w, --word-regexp force PATTERN to match only whole words -x, --line-regexp force PATTERN to match only whole lines -z, --null-data a data line ends in 0 byte, not newline Miscellaneous: // 各種各樣的 -s, --no-messages suppress error messages -v, --invert-match select non-matching lines // 搜尋不匹配的行 -V, --version display version information and exit --help display this help text and exit Output control: // 輸出控制 -m, --max-count=NUM stop after NUM matches -b, --byte-offset print the byte offset with output lines -n, --line-number print line number with output lines --line-buffered flush output on every line -H, --with-filename print the file name for each match -h, --no-filename suppress the file name prefix on output --label=LABEL use LABEL as the standard input file name prefix -o, --only-matching show only the part of a line matching PATTERN -q, --quiet, --silent suppress all normal output --binary-files=TYPE assume that binary files are TYPE; TYPE is 'binary', 'text', or 'without-match' -a, --text equivalent to --binary-files=text -I equivalent to --binary-files=without-match -d, --directories=ACTION how to handle directories; ACTION is 'read', 'recurse', or 'skip' -D, --devices=ACTION how to handle devices, FIFOs and sockets; ACTION is 'read' or 'skip' -r, --recursive like --directories=recurse -R, --dereference-recursive likewise, but follow all symlinks --include=FILE_PATTERN search only files that match FILE_PATTERN --exclude=FILE_PATTERN skip files and directories matching FILE_PATTERN --exclude-from=FILE skip files matching any file pattern from FILE --exclude-dir=PATTERN directories that match PATTERN will be skipped. -L, --files-without-match print only names of FILEs containing no match -l, --files-with-matches print only names of FILEs containing matches -c, --count print only a count of matching lines per FILE -T, --initial-tab make tabs line up (if needed) -Z, --null print 0 byte after FILE name Context control: // 上下文控制 -B, --before-context=NUM print NUM lines of leading context -A, --after-context=NUM print NUM lines of trailing context -C, --context=NUM print NUM lines of output context -NUM same as --context=NUM --color[=WHEN], --colour[=WHEN] use markers to highlight the matching strings; WHEN is 'always', 'never', or 'auto' -U, --binary do not strip CR characters at EOL (MSDOS/Windows) -u, --unix-byte-offsets report offsets as if CRs were not there
看著選項內容真的很多,背起來著實不易,幸好文件中給我們做了分類,只需要記住這些分類是幹什麼的,然後在需要的時候從裡面進行搜尋即可快速搜尋到所需用法(感覺看其內容必看菜鳥教程上的內容容易很多)
(1)當需要透過正則的方式進行搜尋內容時,去"Regexp selection and interpretation"區塊找選項即可,常用的有:
-E:透過正規表示式進行搜尋
(2)當需要對輸出的內容進行控制時,去"Output control"區塊找選項即可,常用的有如下幾個:
-m 數量:表徵匹配多少次就會停止 -n:顯示匹配行及行號 -H:列印每一個匹配的檔名 -r:能夠遞迴查詢,即可以輸入資料夾查詢 -c:統計匹配到行的個數
(3)當需要獲取輸出內容的上下文進行操縱時,去"Context control"區塊找選項即可,常用的有如下幾個:
-B 數量、-A 數量、-C 數量:分別表徵獲取內容前、後、前後幾行 --color:對輸出的內容新增顏色
(4)除了一些劃分比較理解的選項,還有一些選項我個人認為劃分的並不是很合理,但是它們仍然很重要,讓我們一起來看看有哪些:
-i:忽略字母大小寫 -v:反向選擇,也就是顯示出沒有搜尋出字串內容的那一行
上面已經將其基本使用做了詳細的闡述,俗話說的好:光說不練假把式,光練不說真把式,連說帶練全把式。既然上面闡述了一通理論的東西,下面我們就來實戰幾個常用場景,將理論付諸於實踐。在實戰之前先建立一個檔案,檔名是test,檔案內容如下所示:
hello world!!! dog cat pig big pig tiger Elephant
從確定檔案中過濾出包含pig的
$ grep 'pig' ./test pig big pig
從包含某一部分內容的檔案中過濾包含pig的
$ grep 'pig' ./te* pig big pig
從某一資料夾下所有內容中過濾出包含pig的
$ grep -r 'pig' . ./test:pig ./test:big pig
從某一檔案中過濾出不包含pig的
$ grep -v 'pig' ./test hello world!!! dog cat tiger Elephant
在過濾檔案時顯示行數
$ grep -n 'pig' ./test 4:pig 5:big pig
匹配出以開頭的內容(透過基本正規表示式匹配即可,基本正規表示式字元有^$.[]*)
$ grep ^p ./test pig
匹配出包含pig或cat內容的行(用到了擴充套件正規表示式,其在基本正規表示式基礎上增加了(){}?+|等)
$ grep -E 'pig|cat' ./test cat pig big pig
匹配出包含hello和world內容的行
$ grep 'hello' ./test |grep 'world' hello world!!!
獲取到匹配內容‘big pig'的前一行內容
$ grep -B1 'big pig' ./test pig big pig
獲取匹配到'pig'行的數量
$ grep -c 'pig' ./test
獲取到的pig行的內容高亮顯示
$ grep --color 'pig' ./test pig big pig
經典用法還有很多,不能再一一進行羅列了,只需要知道在過濾內容時用此技巧能解決80%的問題,但這就足夠讓自己成為最亮的那個崽。
原文來自:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69955379/viewspace-2854617/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 我們有線上社群啦!快來加入一起玩兒~
- 我們們一起來談談,redis為什麼快?Redis
- 一起玩轉玩轉LiteOS元件:TinyFrame元件
- 我們一起來學RabbitMQ 四,RabbitMQ windows 安裝MQWindows
- 我們一起來學RabbitMQ 四:RabbitMQ windows 安裝MQWindows
- 我們們一起聊聊Java異常Java
- 有類似 比心 陪玩的小程式原始碼的朋友,拿出來我們一起研究啊原始碼
- [我們一起來學 RabbitMQ 一 ]RabbitMQ 的基本介紹MQ
- 來一起讓我們越來越懶,面向CSS、JS未來程式設計CSSJS程式設計
- 物件導向:未來的路我們攜手一起走物件
- 讓我們一起啃演算法----整數反轉演算法
- 姑娘,我們們一起去學程式設計吧程式設計
- 姑娘 我們們一起去學程式設計吧程式設計
- 我們一起來學RabbitMQ 五:RabbitMQ 應知應會的面試題MQ面試題
- 【Linux】find指令和grep指令!!!Linux
- 程式設計師兄弟:我們們一起創業吧!程式設計師創業
- 一起玩轉微服務(1)——概念微服務
- 讓我們來用php編寫一個搶購商品指令碼PHP指令碼
- 我們一起來學RabbitMQ 二:RabbiMQ 的 6 種模式的基本應用MQ模式
- 使用grep命令,玩轉程式碼審計尋找Sink
- 那些年,我們一起追過的APPAPP
- Semantic Web,我們來了Web
- 一起玩轉微服務(12)——揭密starter微服務
- 我們們來聊聊併發工具類Semaphore
- 我們們來聊聊正向代理和反向代理
- 讓我們一起啃演算法----移除元素演算法
- 讓我們一起啃演算法----加一演算法
- 《我們一起進大廠》系列- Redis基礎Redis
- 那些年我們一起踩過的Dubbo坑
- 那些年,我們一起誤解過的RESTREST
- 我們一起學PMP—專案管理的要素專案管理
- 我們一起聊聊什麼是NAT協議協議
- 誰來關心我們這些程式設計師 (轉)程式設計師
- Flutter學習指南App,一起來玩Flutter吧~FlutterAPP
- 我們來聊聊 Vue - compileVueCompile
- 一起玩轉微服務(2)——框架與工具微服務框架
- 我們們worker有力量-在瀏覽器中玩轉多執行緒和離線應用瀏覽器執行緒
- 讓我們一起啃演算法----三數之和演算法