Linux grep 命令用于查找文件里符合條件的字符串。
grep 指令用于查找內容包含指定的范本樣式的文件蛤吓,如果發(fā)現某文件的內容符合所指定的范本樣式闲昭,預設 grep 指令會把含有范本樣式的那一列顯示出來更耻。若不指定任何文件名稱脱羡,或是所給予的文件名為 -,則 grep 指令會從標準輸入設備讀取數據(所以grep支持管道命令)唇辨。
語法
grep [-abcEFGhHilLnqrsvVwxy][-A<顯示行數>][-B<顯示列數>][-C<顯示列數>][-d<進行動作>][-e<范本樣式>][-f<范本文件>][--help][范本樣式][文件或目錄...]
參數
- -a 或 --text : 不要忽略二進制的數據廊酣。
- -A<顯示行數> 或 --after-context=<顯示行數> : 除了顯示符合范本樣式的那一列之外,并顯示該行之后的內容赏枚。
- -b 或 --byte-offset : 在顯示符合樣式的那一行之前啰扛,標示出該行第一個字符的編號。
- -B<顯示行數> 或 --before-context=<顯示行數> : 除了顯示符合樣式的那一行之外嗡贺,并顯示該行之前的內容隐解。
- -c 或 --count : 計算符合樣式的列數。
- -C<顯示行數> 或 --context=<顯示行數>或-<顯示行數> : 除了顯示符合樣式的那一行之外诫睬,并顯示該行之前后的內容煞茫。
- -d <動作> 或 --directories=<動作> : 當指定要查找的是目錄而非文件時,必須使用這項參數摄凡,否則grep指令將回報信息并停止動作续徽。
- -e<范本樣式> 或 --regexp=<范本樣式> : 指定字符串做為查找文件內容的樣式。
- -E 或 --extended-regexp : 將樣式為延伸的正則表達式來使用亲澡。
- -f<規(guī)則文件> 或 --file=<規(guī)則文件> : 指定規(guī)則文件钦扭,其內容含有一個或多個規(guī)則樣式,讓grep查找符合規(guī)則條件的文件內容床绪,格式為每行一個規(guī)則樣式客情。
- -F 或 --fixed-regexp : 將樣式視為固定字符串的列表。
- -G 或 --basic-regexp : 將樣式視為普通的表示法來使用癞己。
- -h 或 --no-filename : 在顯示符合樣式的那一行之前膀斋,不標示該行所屬的文件名稱。
- -H 或 --with-filename : 在顯示符合樣式的那一行之前痹雅,表示該行所屬的文件名稱仰担。
- -i 或 --ignore-case : 忽略字符大小寫的差別。
- -l 或 --file-with-matches : 列出文件內容符合指定的樣式的文件名稱绩社。
- -L 或 --files-without-match : 列出文件內容不符合指定的樣式的文件名稱摔蓝。
- -n 或 --line-number : 在顯示符合樣式的那一行之前赂苗,標示出該行的列數編號。
- -o 或 --only-matching : 只顯示匹配PATTERN 部分贮尉。
- -q 或 --quiet或--silent : 不顯示任何信息拌滋。
- -r 或 --recursive : 此參數的效果和指定"-d recurse"參數相同。
- -s 或 --no-messages : 不顯示錯誤信息绘盟。
- -v 或 --invert-match : 顯示不包含匹配文本的所有行。
- -V 或 --version : 顯示版本信息悯仙。
- -w 或 --word-regexp : 只顯示全字符合的列龄毡。
- -x --line-regexp : 只顯示全列符合的列。
- -y : 此參數的效果和指定"-i"參數相同锡垄。
示例
a.text
[0-9]\{1,\}
hello
b.text
10
20
30
9
8
1
22
33
hello word
執(zhí)行:
grep -w -f a.text b.text
結果
10
20
30
9
8
1
22
33
hello word //若改b.text改為helloword則由于-w存在則不能匹配
執(zhí)行
grep -wx -f a.text b.text //-x 返回全列符合的列沦零,-w 只顯示全字符合的列
結果
10
20
30
9
8
1
22
33