linux下grep命令详解
Posted ultranms
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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仅仅打印匹配的字符,例如以下所看到的:
[[email protected] net]# echo this is line. |grep -o "[a-z]*.$"
line.
[[email protected] net]# echo this is line. |grep -o "[a-z]*."
line.
5. 打印除匹配行之外的其它行,使用-v:
[[email protected] net]# echo -e "1
2
3
4"
1
2
3
4
[[email protected] net]# echo -e "1
2
3
4"|grep -v "[1]"
2
3
4
[[email protected] net]# echo -e "1
2
3
4"|grep -v "[1-2]"
3
4
[[email protected] net]# echo -e "1
2
3
4"|grep -v -E "[1-2]"
3
4
6.统计匹配字符串的行数。使用-c
[[email protected] net]# echo -e "1
2
3
4"|grep "[1,2]" -c
2
7.统计字符串模式匹配的次数。能够结合-o。例如以下:
前面的例子没有加 -o参数
[[email protected] net]# echo -e "11111222"|grep "[1,2]"
11111222
[[email protected] net]# echo -e "11111222"|grep -o "[1,2]"
1
1
1
1
1
2
2
2
8.假设须要显示行号,能够打开-n,例如以下
[[email protected] net]# echo -e "11111
222"|grep -n -o "[1,2]"
1:1
1:1
1:1
1:1
1:1
2:2
2:2
2:2
[[email protected] net]# echo -e "11111
222"|grep -n "[1,2]"
1:11111
2:222
9. -b选项能够打印出匹配的字符串想对于其所在的行起始位置的偏移量(从0開始)。通常配合-o使用,例如以下:
[[email protected] net]# echo "0123456789" | grep -b -o 4
4:4
[[email protected] net]# echo "012333456789" | grep -b -o 4
6:4
10.-P参数(声明grep后面要用的是正则表达式)
[[email protected] net]# echo -e "
line.123
line."|grep -P "[a-z]*.d+"
line.123
[[email protected] net]# echo -e "
line.123
line."|grep -P "[a-z]*."
line.123
line.
[root[email protected] net]# echo -e "
line.123
line."|grep -P "[a-z]*.$"
line.
[[email protected] net]# echo -e "
line.123
line."|grep -P ".$"
line.
11.匹配多个字符串模式
没有-o参数不会只打印匹配项
[[email protected] ~]# echo "This is a line." | grep -e "This" -e "is" -e "line" -e "a"
This is a line.
添加-o参数之后只打印匹配项
[[email protected] ~]# echo "This is a line." | grep -o -e "This"
This
[[email protected] ~]# echo "This is a line." | grep -e "This" -e "is" -e "line" -e "a" -o
This
is
a
line
================================================================
参数oP一起使用,会单独打印出要匹配的数字
[[email protected] a]# echo office365 | grep -oP ‘d+‘
365
只有参数-P,会完整显示匹配内容的一行,匹配内容高亮显示
[[email protected] a]# echo office365 | grep -P ‘d+‘
office365
只有参数-o,不会匹配任何内容,因为没有声明grep要使用正则表达式
[[email protected] a]# echo office365 | grep -o ‘d+‘
[[email protected] a]#
===============================================================
12.打印匹配行上下文信息,使用 -A n打印匹配行及其后n行信息。使用-B n打印匹配行及其前n行信息。使用 -C n。打印匹配行及其前后n行信息。假设有多重匹配,将使用--隔离。
[[email protected] ~]# seq 1 10 | grep 5
5
[[email protected] ~]# seq 1 10 | grep 5 -A 2
5
6
7
[[email protected] ~]# seq 1 10 | grep 5 -A 2 -B 4
1
2
3
4
5
6
7
[[email protected] ~]# seq 1 10 | grep 5 -C 2
3
4
5
6
7
[[email protected] ~]# echo -e "a
b
c
d
a
b
c
d"|grep b -A 1
b
c
--
b
c
[[email protected] ~]# echo -e "a
b
c
d
a
b
c
d"|grep b -B 1
a
b
--
a
b
[[email protected] ~]# echo -e "a
b
c
d
a
b
c
d"|grep b -C 1
a
b
c
--
a
b
c
13.-Z选项在输出匹配文件名称时将以/0结尾配合xargs -0能够发挥非常多作用,比如删除匹配某个模式的文件例如以下:
[[email protected] a]# echo linux >> a.txt
[[email protected] a]# echo linux >> b.txt
[[email protected] a]# echo li >> c.txt
[[email protected] a]# grep -lZ "linux" *|xargs -0 rm
[[email protected] a]# ls
c.txt
以上命令将包括linux字符串的a.txt和b.txt删除。
14.限定全字匹配选项:-w
[[email protected] a]# grep -rn "li" *
a.txt:1:linux
b.txt:1:linux
c.txt:1:li
[[email protected] a]# grep -rnw "li" *
c.txt:1:li
15.-E参数是同时匹配多个关键字
[[email protected] 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
[[email protected] 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参数同样是匹配多个关键字
[[email protected] 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
再列一个例子:
[[email protected] a]# cat d.txt
1 5
2 3
3 2
2 3 4
5
6
7
[[email protected] a]# grep -E ‘2|3‘ d.txt
2 3
3 2
2 3 4
[[email protected] a]# egrep ‘2|3‘ d.txt
2 3
3 2
2 3 4
[[email protected] a]# grep -e 2 -e 3 d.txt
2 3
3 2
2 3 4
以上是关于linux下grep命令详解的主要内容,如果未能解决你的问题,请参考以下文章