一些会比较经常用到的Linux下的工具,当然都是命令行。多数工具需要与正则表达式配合使用,所以可以很多工具使用前都需要先了解正则表达式,正则表达式可以参考这里正则表达式学习笔记
关于
grep的作用就是根据模式(可以是正则表达式或字符串)打印匹配到的内容到标准输出,即可以对管道输出的内容进行匹配,也可以对文件或文件下的文件进行匹配。如果不使用-P指定正则表达式语法兼容Perl,则默认使用-G参数,指定为基本正则表达式
用法(来自于man手册):
| 1 | grep [OPTIONS] PATTERN [FILE...] | 
OPEIONS的可选项有很多,比较常见的有(加粗表示很实用):
匹配模式选择
 -E, –extended-regexp     扩展正则表达式egrep
 -F, –fixed-strings       一个换行符分隔的字符串的集合fgrep
 -G, –basic-regexp        基本正则
 -P, –perl-regexp         调用的perl正则
 -e, –regexp=PATTERN      后面根正则模式,默认就是这个选项
 -f, –file=FILE           从文件中获得匹配模式
-i, –ignore-case         不区分大小写
-w, –word-regexp         匹配整个单词
-x, –line-regexp         匹配整行
 -z, –null-data           a data line ends in 0 byte, not newline  
杂项:
 -s, –no-messages         不显示错误信息
-v, –invert-match        显示不匹配的行
 -V, –version             显示版本号
 –help                    显示帮助信息
 –mmap                use memory-mapped input if possible  
输出控制
 -m, –max-count=NUM       显示每一个文件中匹配到的最大次数
 -b, –byte-offset         打印匹配行前面打印该行所在的块号码。
-n, –line-number         显示的加上匹配所在的行号
 –line-buffered           刷新输出每一行
 -H, –with-filename       当搜索多个文件时,显示匹配文件名前缀
 -h, –no-filename         当搜索多个文件时,不显示匹配文件名前缀
 –label=LABEL            print LABEL as filename for standard input
-o, –only-matching       只显示匹配成功的内容,而不是整行。当某个匹配在一行中多次出现,每一个都单独显示一次(与-c配合可以输出某个串一共出现了多少次)
-q, –quiet, –silent     不显示任何东西,但可以用于检查grep的退出状态(0为匹配成功)
 –binary-files=TYPE   assume that binary files are TYPE TYPE is ‘binary’, ‘text’, or ‘without-match’
 -a, –text                匹配二进制的东西
 -I                        不匹配二进制的东西
 -d, –directories=ACTION  目录操作,读取,递归,跳过
 ACTION is ‘read’, ‘recurse’, or ‘skip’
 -D, –devices=ACTION      设置对设备,FIFO,管道的操作,读取,跳过
      ACTION is ‘read’ or ‘skip’
-R, -r, –recursive       递归调用
其中-R会递归符号链接目录,-r只递归当前真实目录,而忽略链接目录
 –include=PATTERN     files that match PATTERN will be examined
 –exclude=PATTERN     files that match PATTERN will be skipped.
 –exclude-from=FILE   files that match PATTERN in FILE will be skipped.
 -L, –files-without-match 匹配多个文件时,显示不匹配的文件名
-l, –files-with-matches  匹配多个文件时,显示匹配的文件名
-c, –count               显示匹配了多少次
 -Z, –null                print 0 byte after FILE name  
文件控制:
 -B, –before-context=NUM  打印匹配本身以及前面的几个行由NUM控制
 -A, –after-context=NUM   打印匹配本身以及随后的几个行由NUM控制
-C, –context=NUM         打印匹配本身以及随后,前面的几个行由NUM控制
-NUM                      根-C的用法一样的
 –color[=WHEN],
 –colour[=WHEN]       use markers to distinguish the matching string
 WHEN may be always, never or auto.
 -U, –binary              do not strip CR characters at EOL (MSDOS)
 -u, –unix-byte-offsets   report offsets as if CRs were not there (MSDOS) 
实例分析
1.查看grep的man手册中-A参数的作用:
| 1 | man grep | grep '^\s*\-A' -A 3 | 
首先man手册,然后通过管道使用grep查询以-A开头的行,并通过-A参数,指定输出匹配行及其后3行。结果为:
| 1 | -A NUM, --after-context=NUM | 
2.查看系统头文件中固定大小的整型是不是通过typedef进行定义的:
| 1 | grep -ni 'typedef\s\+.*\s\+uint[[:digit:]]*_t' /usr/include/*.h | 
使用-n参数显示行号,-i参数忽略大小写,注意正则表达式中匹配一个或多个的+号在这里需要进行转义,否则表示正常匹配+号。\d不能用于匹配数字,需要使用posix的正则表示法,而且方括号还必须是双方括号。最后的文件名,可以使用通配符。
注意上述语句等价于使用-P参数指定为Perl正则语法的语句:
| 1 | grep -niP 'typedef\s+.*\s+uint\d*_t' /usr/include/*.h | 
输出结果为:
| 1 | /usr/include/stdint.h:48:typedef unsigned char uint8_t; | 
3.递归匹配头文件中含有单个字符串grep的文件,并显示文件名和行号:
| 1 | grep -rniw 'grep' /usr/include/ | 
使用-r参数,递归匹配,-w进行整词匹配
更多内容可以参见man手册
GNU的grep手册: https://www.gnu.org/software/grep/manual/grep.html