linux下grep命令詳解


參數

  • -a 或 --text : 不要忽略二進制的數據。
  • -A<顯示行數> 或 --after-context=<顯示行數> : 除了顯示符合范本樣式的那一列之外,並顯示該行之后的內容。
  • -b 或 --byte-offset : 在顯示符合樣式的那一行之前,標示出該行第一個字符的編號。
  • -B<顯示行數> 或 --before-context=<顯示行數> : 除了顯示符合樣式的那一行之外,並顯示該行之前的內容。
  • -c 或 --count : 計算符合樣式的列數。
  • -C<顯示行數> 或 --context=<顯示行數>或-<顯示行數> : 除了顯示符合樣式的那一行之外,並顯示該行之前后的內容。
  • -d <動作> 或 --directories=<動作> : 當指定要查找的是目錄而非文件時,必須使用這項參數,否則grep指令將回報信息並停止動作。
  • -e<范本樣式> 或 --regexp=<范本樣式> : 指定字符串做為查找文件內容的樣式。
  • -E 或 --extended-regexp : 將樣式為延伸的普通表示法來使用。
  • -f<規則文件> 或 --file=<規則文件> : 指定規則文件,其內容含有一個或多個規則樣式,讓grep查找符合規則條件的文件內容,格式為每行一個規則樣式。
  • -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 : 在顯示符合樣式的那一行之前,標示出該行的列數編號。
  • -q 或 --quiet或--silent : 不顯示任何信息。
  • -r 或 --recursive : 此參數的效果和指定"-d recurse"參數相同。
  • -s 或 --no-messages : 不顯示錯誤信息。
  • -v 或 --revert-match : 顯示不包含匹配文本的所有行。
  • -V 或 --version : 顯示版本信息。
  • -w 或 --word-regexp : 只顯示全字符合的列。
  • -x --line-regexp : 只顯示全列符合的列。
  • -y : 此參數的效果和指定"-i"參數相同。

1. grep最簡單的用法,匹配一個詞:grep word filename

2. 能夠從多個文件里匹配:grep word filename1 filenam2 filename3

3. 能夠使用正則表達式匹配:grep -E pattern f1 f2 f3...

4. 能夠使用-o僅僅打印匹配的字符,例如以下所看到的:

[root@zabbix net]# echo this is line. |grep -o "[a-z]*.$"
line.
[root@zabbix net]# echo this is line. |grep -o "[a-z]*\."
line.

5. 打印除匹配行之外的其它行,使用-v:

[root@zabbix net]# echo -e "1\n2\n3\n4"
1
2
3
4
[root@zabbix net]# echo -e "1\n2\n3\n4"|grep -v "[1]"
2
3
4
[root@zabbix net]# echo -e "1\n2\n3\n4"|grep -v "[1-2]"
3
4
[root@zabbix net]# echo -e "1\n2\n3\n4"|grep -v -E "[1-2]"
3
4

6.統計匹配字符串的行數。使用-c

[root@zabbix net]# echo -e "1\n2\n3\n4"|grep "[1,2]" -c
2

7.統計字符串模式匹配的次數。能夠結合-o。例如以下:

前面的例子沒有加 -o參數

[root@zabbix net]# echo -e "11111\222"|grep "[1,2]"
11111\222

[root@zabbix net]# echo -e "11111\222"|grep -o "[1,2]"
1
1
1
1
1
2
2
2
8.假設須要顯示行號,能夠打開-n,例如以下

[root@zabbix net]# echo -e "11111\n222"|grep -n -o "[1,2]"
1:1
1:1
1:1
1:1
1:1
2:2
2:2
2:2
[root@zabbix net]# echo -e "11111\n222"|grep -n "[1,2]"
1:11111
2:222

9. -b選項能夠打印出匹配的字符串想對於其所在的行起始位置的偏移量(從0開始)。通常配合-o使用,例如以下:

[root@zabbix net]# echo "0123456789" | grep -b -o 4
4:4
[root@zabbix net]# echo "012333456789" | grep -b -o 4
6:4

10.-P參數(聲明grep后面要用的是正則表達式)

[root@zabbix net]# echo -e "\nline.123\nline."|grep -P "[a-z]*\.\d+"
line.123
[root@zabbix net]# echo -e "\nline.123\nline."|grep -P "[a-z]*\."
line.123
line.
[root@zabbix net]# echo -e "\nline.123\nline."|grep -P "[a-z]*\.$"
line.
[root@zabbix net]# echo -e "\nline.123\nline."|grep -P "\.$"
line.

11.匹配多個字符串模式

沒有-o參數不會只打印匹配項

[root@zabbix ~]# echo "This is a line." | grep -e "This" -e "is" -e "line" -e "a"
This is a line.

添加-o參數之后只打印匹配項

[root@zabbix ~]# echo "This is a line." | grep -o -e "This"
This
[root@zabbix ~]# echo "This is a line." | grep -e "This" -e "is" -e "line" -e "a" -o
This
is
a
line

================================================================

參數oP一起使用,會單獨打印出要匹配的數字

[root@zabbix a]# echo office365 | grep -oP '\d+'
365

只有參數-P,會完整顯示匹配內容的一行,匹配內容高亮顯示
[root@zabbix a]# echo office365 | grep -P '\d+'
office365

只有參數-o,不會匹配任何內容,因為沒有聲明grep要使用正則表達式
[root@zabbix a]# echo office365 | grep -o '\d+'
[root@zabbix a]#

===============================================================

12.打印匹配行上下文信息,使用 -A n打印匹配行及其后n行信息。使用-B n打印匹配行及其前n行信息。使用 -C n。打印匹配行及其前后n行信息。假設有多重匹配,將使用--隔離。

[root@zabbix ~]# seq 1 10 | grep 5
5
[root@zabbix ~]# seq 1 10 | grep 5 -A 2
5
6
7
[root@zabbix ~]# seq 1 10 | grep 5 -A 2 -B 4
1
2
3
4
5
6
7
[root@zabbix ~]# seq 1 10 | grep 5 -C 2
3
4
5
6
7

[root@zabbix ~]# echo -e "a\nb\nc\nd\na\nb\nc\nd"|grep b -A 1
b
c
--
b
c
[root@zabbix ~]# echo -e "a\nb\nc\nd\na\nb\nc\nd"|grep b -B 1
a
b
--
a
b
[root@zabbix ~]# echo -e "a\nb\nc\nd\na\nb\nc\nd"|grep b -C 1
a
b
c
--
a
b
c

13.-Z選項在輸出匹配文件名稱時將以/0結尾配合xargs -0能夠發揮非常多作用,比如刪除匹配某個模式的文件例如以下:

[root@zabbix a]# echo linux >> a.txt
[root@zabbix a]# echo linux >> b.txt
[root@zabbix a]# echo li >> c.txt

[root@zabbix a]# grep -lZ "linux" *|xargs -0 rm

[root@zabbix a]# ls
c.txt

以上命令將包括linux字符串的a.txt和b.txt刪除。

14.限定全字匹配選項:-w

[root@zabbix a]# grep -rn "li" *
a.txt:1:linux
b.txt:1:linux
c.txt:1:li
[root@zabbix a]# grep -rnw "li" *
c.txt:1:li

15.-E參數是同時匹配多個關鍵字

[root@zabbix a]# cat /etc/passwd|grep -E "root|long"
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
long:x:1002:1002::/home/long:/bin/bash

grep -E同egrep

[root@zabbix a]# cat /etc/passwd|egrep "root|lilong"
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
lilong:x:1002:1002::/home/long:/bin/bash

-e參數同樣是匹配多個關鍵字
[root@zabbix a]# cat /etc/passwd|grep -e root -e long
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
long:x:1002:1002::/home/long:/bin/bash

再列一個例子:

[root@zabbix a]# cat d.txt
1 5
2 3
3 2
2 3 4
5
6
7

[root@zabbix a]# grep -E '2|3' d.txt
2 3
3 2
2 3 4
[root@zabbix a]# egrep '2|3' d.txt
2 3
3 2
2 3 4
[root@zabbix a]# grep -e 2 -e 3 d.txt
2 3
3 2
2 3 4


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM