一、grep命令基本介绍

grep 命令(Global search REgular expression and Print out the line) 是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. 配合管道符进行匹配

配合管道|搜索某个目录下包含ab关键字的文件

# 显示匹配到的文件
ls | grep -E "(a|b)"

# 显示匹配到文件的个数
ls | grep -cE "(a|b)"

在这里插入图片描述

Logo

有“AI”的1024 = 2048,欢迎大家加入2048 AI社区

更多推荐