一、grep命令基本介绍
grep命令(GlobalsearchREgularexpressionandPrintouttheline)是linux中一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。用于过滤/搜索的特定字符,可以配合正则表达式组合多种搜索命令。
语法:grep[options][pattern]搜索文件
常用的options(选项)
选项 | 含义 |
---|---|
-n | 显示匹配到的行号 |
-v | 反转查找,排除要匹配的结果 |
-c | 只统计匹配到结果的行数 |
-i | 不区分大小写 |
-o | 只输出文件中匹配到的部分 |
-w | 只匹配过滤的单词 |
-E | 使用扩展正则表达式 |
常用的pattern(规则表达式)
规则 | 含义 |
---|---|
"" | 直接输入要匹配的内容,简单字符串可以不带双引号,复杂的字符串建议带上双引号 |
^ | 匹配以目标字符串开头的行 |
$ | 匹配以目标字符串结尾的行 |
. | 匹配一个非换行符的字符 |
* | 匹配零个或多个先前字符 |
.* | 匹配任意字符 |
[] | 匹配一个指定范围内的字符 |
[^] | 匹配一个不在指定范围内的字符 |
\w | 匹配文字和数字字符,也就是[A-Za-z0-9] |
\W | w的反置形式,匹配一个或多个非单词字符,如点号句号等 |
二、grep命令常见的用法
首先我们在linux中,创建一个测试文件,文件内容如下:
1.匹配包含关键词的所有行
在文件中搜索包含hello
关键词的所有行
#不带行号grep"hello"a.txt#带行号grep-n"hello"a.txt
2.匹配不包含关键词的所有行
在文件中匹配不包含关键词hello
的所有行
grep-v"hello"a.txt
3.统计包含关键词的行数
统计包含关键词hello
的的行数
grep-c"hello"a.txt
4.统计包含关键词所有行数,不区分大小写
统计文件中包含关键词spark
的所有行数,不区分大小写
grep-i"spark"a.txt
5.输出匹配关键词的部分
输出匹配到关键词hello
的部分
grep-o"hello"a.txt
6.正则表达式匹配多个关键词
使用正则表达式匹配既包含关键词pytorch
又包含关键词hello
的所有行
grep-E"(pytorch|hello)"a.txt
7.多种匹配方式组合使用
多种选项组合使用,比如匹配既包含关键词spark
又包含关键词hello
的所有行,显示行号、不区分大小写、使用正则表达式
grep-inE"(spark|hello)"a.txt
8.配合管道符进行匹配
配合管道|
搜索某个目录下包含a
或b
关键字的文件
#显示匹配到的文件ls|grep-E"(a|b)"#显示匹配到文件的个数ls|grep-cE"(a|b)"