1 命令介绍
grep 命令是linux中一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。用于过滤/搜索的特定字符,可以配合正则表达式组合多种搜索命令。
1.1 选项和参数
语法:grep [options] [pattern] 搜索文件
常用的options(选项)
选项 | 含义 |
---|---|
-A | 后面加数字,比如A2,after 2行的意思 |
-B | 后面加数字,比如B3,before 3行的意思 |
-c | 只统计匹配到结果的行数 |
-E | 使用扩展正则表达式 |
-i | 不区分大小写 |
-n | 显示匹配到的行号 |
-o | 只输出文件中匹配到的部分 |
-v | 反转查找,排除要匹配的结果 |
-w | 只匹配过滤的单词 |
常用的pattern(规则表达式)
则 | 含义 |
---|---|
" " | 直接输入要匹配的内容,简单字符串可以不带双引号,复杂的字符串建议带上双引号 |
^ | 匹配以目标字符串开头的行 |
$ | 匹配以目标字符串结尾的行 |
. | 匹配一个非换行符的字符 |
* | 匹配零个或多个先前字符 |
.* | 匹配任意字符 |
[] | 匹配一个指定范围内的字符 |
[^] | 匹配一个不在指定范围内的字符 |
\w | 匹配文字和数字字符,也就是[A-Za-z0-9] |
\W | w的反置形式,匹配一个或多个非单词字符,如点号句号等 |
\b | # 单词锁定符,如: '\bgrep\b'只匹配grep。 |
2 输出结果
1. 匹配包含关键词的所有行
在文件中搜索包含hello
关键词的所有行,-n可以带行号,-i不区分大小写
2. 匹配不包含关键词的所有行
在文件中匹配不包含关键词hello
的所有行
grep -v 'hello' a.txt
grep '[^hello]' a.txt
3. 统计包含关键词的行数
统计包含关键词hello
的的行数
4. 输出匹配关键词的部分
输出匹配到关键词hello
的部分
5. 正则表达式匹配多个关键词
使用正则表达式匹配既包含关键词world
又包含关键词hello
的所有行
grep -E "world|hello" a.txt
grep "world\|hello" a.txt
上面两个命令是查找包含任意一个,或者两个都包含的行
如果要同时包含两个可以用下面的方法
grep 'world' a.txt | grep 'hello'
grep -P 'world.*hello|hello.*world' a.txt
6. 查找以匹配字符为结束的行
grep '\.$' a.txt