- grep:文本行过滤工具 sed:
- 文本行编辑器(流编辑器)
- awk: 报告生成器,输出格式化
grep的用法结构:
grep [option] PATTERN [filename]
[option]常用可选参数
-v:invert,反转查找,输出与模式不相符的行;(==反选==)
-An:after-context,同时显示符合条件行的下面n行;(==显示该行及之后==)
-Bn:before-context,同时显示符合条件行的上面n行;(==显示该行及之前==)
-Cn:同时显示符合条件行的上面n行和下面n行;
-E:extended regular,支持扩展正则表达式;
-o:only-matching,仅显示匹配的字符串;
-f:根据文件内容进行匹配;
-d:--directories=<进行动作> 当指定要查找的是==目录==而非文件时,必须使用这项参数,否则grep指令将回报信息并停止动作。
-a:以文本文件方式搜索,不忽略二进制的数据;
-c:计算找到的符合行的次数;
-i:ignore-case忽略大小写;
-n:line-number,在显示符合范本样式的那一行之前,标示出该行的行数编号;
-P "\t" --》得到Tab键 --》使用perl语言的正则语法,支持\t表示table键,\s表示空白。
-r:--recursive 此参数的效果和指定“-d recurse”参数相同。(==递归遍历目录查找==)
pattern–正则表达式:
模式其实就是一个公式,里面有字母+数字+特殊符号,组合成一个正则表达式,表达出某个含义。
1.字符匹配:
. 任意一个字符
[] 范围内的任意一个字符
[^]范围外的任意一个字符
字符类:[:digit:] [:alnum:] [:alpha:] [:lower:] [:upper:] [:space:] [:punct:]
2.次数匹配
* 匹配前面的字符0次到n次
\?匹配前面的字符0次到1次
+ 匹配前面的字符1次到n次
\{m\}匹配前面的字符m次
\{m,n\}匹配前面的字符m到n次
\{0,n\}匹配前面的字符0到n次
\{m,\} 匹配前面的字符至少m次
3.位置锚定
^ 锚定行首
$ 锚定行尾
\b 锚定词首和锚定词尾
\> 锚定词尾
<\ 锚定词首
grep 搜索含子目录的目录
默认情况下,’grep’只搜索当前目录。如果 此目录下有许多子目录,’grep’会以如下形式列出:
grep: sound: Is a directory
这可能会使’grep’ 的输出难于阅读。这里有两种解决的办法:
明确要求搜索子目录:grep -r
或忽略子目录:grep -d skip
🐖 如果有很多输出时,可以通过管道将其转到’less’上阅读:
$ grep magic /usr/src/Linux/Documentation/* | less