通过使用grep命令,我们可以在文本文件中找到感兴趣的文字,甚至从其他程序的输出中进行搜索。
本章的主要知识点
(1)使用grep命令搜索文件中的字符串;
(2)使用grep命令搜索其他命令的输出;
(3)正则表达式的各种高级用法。
1. grep的基本用法
grep命令的作用是在文本文件中搜索指定的字符串,并且把匹配成功的行数据打印到终端。执行grep命令的语法格式如下:
grep [options] [regular expression][filename…]
案例1
如何查看当前计算机所使用的CPU型号?
#CPU型号保存在/proc/cpuinfo文件的model name字段中
$grep “model name” /proc/cpuinfo
主要参数 [options]
-c : 只输出匹配的行
-I : 不区分大小写
-h : 查询多文件时不显示文件名
-l : 查询多文件时, 只输出包含匹配字符的文件名
-n : 显示匹配的行号及行
-v : 显示不包含匹配文本的所有行(我经常用除去grep本身)
2. 高级正则表达式
正则表达式可以指定字符的范围:
集合 | 含义 |
[a-z] | 匹配一个小写字母 |
[A-Z] | 匹配一个大写字母 |
[a- zA-Z] | 匹配一个字母 |
[a- zA-Z0-9] | 匹配一个字母或数字 |
案例1:
如何使用grep命令匹配文本文件中的一个email地址呢?
#使用选项-E来支持扩展正则表达式
$grep –E “[ a-zA-Z0-9_.- ]+@[ a-zA-Z0-9_.-]+\.[ a-zA-Z0-9 ]+” CREDITS
#grep命令中@用来匹配自己,因@是普通字符,所以不需要转义;+是指匹配一个或多个加号+前面的字符。注意,使用加号+进行匹配时,至少要匹配一个。
在扩展正则表达式中,可以方便使用一些特殊字符,如?,+,{n,m},()等,从而构建更加强大、更加复杂的搜索模式。
案例2:
上一个例子,可能是以点.开头,该如何避免这种情况出现?