举例讲解Linux下grep命令的精彩使用技巧

时间:2021-10-17 03:09:12

grep 命令用来搜索文本,或从给定的文件中搜索行内包含了给定字符串或单词的文件。通常来说,grep 显示匹配到的行。使用 grep 来搜索包括一个或多个正则表达式匹配到的文本行,然后只显示匹配到的行。grep 被视作在 Linux/ Unix 系统中最有用的命令之一。

grep 这个名字,来源于一个 Unix/Linux 中的古老的行编辑器 ed 中执行相似操作的命令:
 

复制代码

代码如下:


g/re/p


grep 命令的语法

 

语法如下所示:

grep 'word' 文件名
grep 'word' 文件1 文件2 文件3
grep '字符串1 字符串2'  文件名
cat 某个文件 | grep '某个东西'
command | grep '某个东西'
command 选项1 | grep '数据'
grep --color '数据' 文件名
怎么样使用 grep 来搜索一个文件

搜索 /etc/passwd 文件下的 boo 用户,输入:
 

复制代码

代码如下:


$ grep boo /etc/passwd


输出内容:

复制代码

代码如下:


foo:x:1000:1000:foo,,,:/home/foo:/bin/ksh


可以使用 grep 去强制忽略大小写。例如,使用 -i 选项可以匹配 boo, Boo, BOO 和其他组合:

复制代码

代码如下:


$ grep -i "boo" /etc/passwd


递归使用 grep

 

你可以递归地使用 grep 进行搜索。例如,在文件目录下面搜索所有包含字符串“192.168.1.5”的文件
 

复制代码

代码如下:


$ grep -r "192.168.1.5" /etc/


或者是:

复制代码

代码如下:


$ grep -R "192.168.1.5" /etc/


示例输出:

复制代码

代码如下:


/etc/ppp/options:# ms-wins 192.168.1.50
/etc/ppp/options:# ms-wins 192.168.1.51
/etc/NetworkManager/system-connections/Wired connection 1:addresses1=192.168.1.5;24;192.168.1.2;


你会看到搜索到 192.168.1.5 的结果每一行都前缀以找到匹配的文件名(例如:/etc/ppp/options)。输出之中包含的文件名可以加 -h 选项来禁止输出:

复制代码

代码如下:


$ grep -h -R "192.168.1.5" /etc/


或者

复制代码

代码如下:


$ grep -hR "192.168.1.5" /etc/


示例输出:

复制代码

代码如下:


# ms-wins 192.168.1.50
# ms-wins 192.168.1.51
addresses1=192.168.1.5;24;192.168.1.2;


使用 grep 去搜索文本

 

当你搜索 boo 时,grep 命令将会匹配 fooboo,boo123, barfoo35 和其他所有包含 boo 的字符串,你可以使用 -w 选项去强制只输出那些仅仅包含那个整个单词的行(LCTT译注:即该字符串两侧是英文单词分隔符,如空格,标点符号,和末端等,因此对中文这种没有断字符号的语言并不适用。)。
 

复制代码

代码如下:


$ grep -w "boo" file


使用 grep 命令去搜索两个不同的单词

 

使用 egrep 命令如下:
 

复制代码

代码如下:


$ egrep -w 'word1|word2' /path/to/file


(注:这里使用到了正则表达式,因此使用的是 egrep 命令,即扩展的 grep 命令。)

 

统计文本匹配到的行数

grep 命令可以通过加 -c 参数显示每个文件中匹配到的次数:
 

复制代码

代码如下:


$ grep -c 'word' /path/to/file


传递 -n 选项可以输出的行前加入匹配到的行的行号:

复制代码

代码如下:


$ grep -n 'root' /etc/passwd


示例输出:

复制代码

代码如下:


1:root:x:0:0:root:/root:/bin/bash
1042:rootdoor:x:0:0:rootdoor:/home/rootdoor:/bin/csh
3319:initrootapp:x:0:0:initrootapp:/home/initroot:/bin/ksh


反转匹配(不匹配)

 

可以使用 -v 选项来输出不包含匹配项的内容,输出内容仅仅包含那些不含给定单词的行,例如输出所有不包含 bar 单词的行:
 

复制代码

代码如下:


$ grep -v bar /path/to/file


UNIX/Linux 管道与 grep 命令

 

grep 常常与管道一起使用,在这个例子中,显示硬盘设备的名字:
 

复制代码

代码如下:


# dmesg | egrep '(s|h)d[a-z]'


显示 CPU 型号:

复制代码

代码如下:


# cat /proc/cpuinfo | grep -i 'Model'


然而,以上命令也可以按照以下方法使用,不使用管道:

复制代码

代码如下:


# grep -i 'Model' /proc/cpuinfo


示例输出:

复制代码

代码如下:


model : 30
model name : Intel(R) Core(TM) i7 CPU Q 820 @ 1.73GHz
model : 30
model name : Intel(R) Core(TM) i7 CPU Q 820 @ 1.73GHz


如何仅仅显示匹配到内容的文件名字?

 

使用 -l 选项去显示那些文件内容中包含 main() 的文件名:
 

复制代码

代码如下:


$ grep -l 'main' *.c


最后,你可以强制 grep 以彩色输出:

复制代码

代码如下:


$ grep --color vivek /etc/passwd


示例输出:
举例讲解Linux下grep命令的精彩使用技巧