参数:
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
原文:https://www.cnblogs.com/ultranms/p/9517752.html