一、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. 配合管道符进行匹配
配合管道|
搜索某个目录下包含a
或b
关键字的文件文章来源:https://www.toymoban.com/news/detail-737832.html
# 显示匹配到的文件
ls | grep -E "(a|b)"
# 显示匹配到文件的个数
ls | grep -cE "(a|b)"
文章来源地址https://www.toymoban.com/news/detail-737832.html
到了这里,关于linux中grep命令详解及使用示例的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!