简介
grep
命令是最常用的Linux命令之一,用于对文件和文本执行重复搜索的工具,功能非常强大,也是我们必须学习掌握的Linux三剑客之一,本文就给大家介绍一下grep
命令的使用。
grep的基本语法
grep
作为一款文本搜索工具,可以根据用户指定的“模式(过滤条件)”对目标文本逐行进行匹配检查,打印匹配到的行,基本的语法如下:
grep [options] [pattern] file | |
命令 参数 匹配模式 文件 |
常用的参数如下:
-i
:忽略模式中的字母大小写。-c
:仅列出文件中包含模式的行数。-l
:列出带有匹配行的文件名。-v
:列出没有匹配模式的行。-w
: 把表达式当做一个完整的单字符来搜寻,忽略那些部分匹配的行。-o
:只输出匹配的内容。-E
:使用egrep
命令。
grep命令使用实践
首先我们来看一下我们需要操作的文件的内容,命令如下:
cat -n test.txt | |
1 I am a coach | |
2 I am a player | |
3 I like Linux | |
4 I like python | |
5 hello world | |
6 | |
7 mia san mia | |
8 12312341 | |
9 321789 | |
10 abcdrstxyz. | |
11 efglmnuvw. | |
12 | |
13 #tigaffpubg | |
14 #theshyrookie | |
15 | |
16 i believe i can fly |
- 输出以
I
开头的行(不区分大小写)
grep "^i" test.txt -i -n | |
1:I am a coach | |
2:I am a player | |
3:I like Linux | |
4:I like python | |
16:i believe i can fly |
注: 这里的-i
参数代表不区分大小写, -n
参数代表显示匹配行和行号。
- 输出以
.
结尾的行
grep "\.$" test.txt -n | |
10:abcdrstxyz. | |
11:efglmnuvw. |
注: 因为.
在这里有着特殊含义, 所以要用\
转义一下, 如果不加转义字符的话, grep就会把它当做正则表达式来处理(.
代表的含义是匹配任意一个字符)
$
符号
在Linux平台下, 所有文件每行结尾都有一个$
符,我们可以使用cat
命令进行查看,如下:
$ cat -A test.txt | |
I am a coach$ | |
I am a player$ | |
I like Linux$ | |
I like python$ | |
hello world$ | |
$ | |
mia san mia$ | |
12312341$ | |
321789$ | |
abcdrstxyz.$ | |
efglmnuvw.$ | |
$ | |
#tigaffpubg$ | |
#theshyrookie$ | |
$ | |
i believe i can fly$ | |
- 查找空行
^$
即表示空行,找出空行的命令如下:
$ grep "^$" test.txt -n | |
6: | |
12: | |
15: |
- 查找有内容的行
.
点表示任意一个字符, 有且只有一个, 不包含空行,所以输出有内容的行命令如下:
$ grep "." test.txt -n | |
1:I am a coach | |
2:I am a player | |
3:I like Linux | |
4:I like python | |
5:hello world | |
7:mia san mia | |
8:12312341 | |
9:321789 | |
10:abcdrstxyz. | |
11:efglmnuvw. | |
13:#tigaffpubg | |
14:#theshyrookie | |
16:i believe i can fly |
- "*"符号
*
表示找出前一个字符0次或一次以上,命令如下:
$ grep "i*" test.txt -n | |
1:I am a coach | |
2:I am a player | |
3:I like Linux | |
4:I like python | |
5:hello world | |
6: | |
7:mia san mia | |
8:12312341 | |
9:321789 | |
10:abcdrstxyz. | |
11:efglmnuvw. | |
12: | |
13:#tigaffpubg | |
14:#theshyrookie | |
15: | |
16:i believe i can fly |
.*
组合符
.*
表示所有内容, 包括空行,示例代码如下:
$ grep ".*" test.txt -n | |
1:I am a coach | |
2:I am a player | |
3:I like Linux | |
4:I like python | |
5:hello world | |
6: | |
7:mia san mia | |
8:12312341 | |
9:321789 | |
10:abcdrstxyz. | |
11:efglmnuvw. | |
12: | |
13:#tigaffpubg | |
14:#theshyrookie | |
15: | |
16:i believe i can fly |
[]
中括号
中括号表达式,[abc]
表示匹配中括号中任意一个字符, a
或b
或c
,常见的形式如下,
[a-z]
匹配所有小写单个字母[A-Z]
匹配所有单个大写字母[a-zA-Z]
匹配所有的单个大小写字母[0-9]
匹配所有单个数字[a-zA-ZO-9]
匹配所有数字和字母
匹配abc
字符中的任意一个,得到它的行数和行号
$ grep "[abc]" test.txt -n | |
1:I am a coach | |
2:I am a player | |
7:mia san mia | |
10:abcdrstxyz. | |
13:#tigaffpubg | |
16:i believe i can fly |
注:如果我们想查看不包含abc
字符的行,则可以写成[^abc]
-o
参数
使用-o
参数, 可以值显示被匹配到的关键字, 而不是将整行的内容都输出。命令如下:
grep "[abc]" test.txt -n -o | |
1:a | |
1:a | |
1:c | |
1:a | |
1:c | |
2:a | |
2:a | |
2:a | |
7:a | |
7:a | |
7:a | |
10:a | |
10:b | |
10:c | |
13:a | |
13:b | |
16:b | |
16:c | |
16:a |
查看一共有多少行,我们可以改用-c
参数,命令如下:
$ grep "[abc]" test.txt -c | |
6 |
扩展正则表达式grep
grep
命令结合正则之后,功能将更为强大,我们这里使用-E
进行正则扩展。
+
号
+
号表示匹配前一个字符1一次或多次,必须使用grep -E
扩展正则,命令如下:
$ grep -E "i+" test.txt -n | |
3:I like Linux | |
4:I like python | |
7:mia san mia | |
13:#tigaffpubg | |
14:#theshyrookie | |
16:i believe i can fly |
?
符
匹配前一个字符0次或1次,命令使用如下:
$ grep -E "li?e" test.txt -n | |
16:i believe i can fly |
{n,m}
匹配次数
{n,m}
:匹配前一个字符至少n次, 最多m次{n,}
: 匹配前一个字符至少n次, 没有上限{,m}
: 匹配前一个字符最多m次,可以没有
示例命令如下:
$ grep -E "a{1,3}" test.txt | |
I am a coach | |
I am a player | |
mia san mia | |
abcdrstxyz. | |
#tigaffpubg | |
i believe i can fly |
总结
本文主要介绍了Linux三剑客中的grep
命令的使用,这是一个功能非常强大的文本内容搜索工具,熟练的使用grep
命令,对于我们学好软件测试开发的课程有很大的帮助,希望本文能够帮到大家!