grep的用法
作用:文本搜索工具,根据用户指定的“模式(过滤条件)”对目标文本逐行进行匹配检查;打印匹配到的行;
模式:由正则表达式的元字符及文本字符所编写出的过滤条件;
正则表达式:由一类特殊字符及文本字符所编写的模式,其中有些字符不表示其字面意义,而是用于表示控制或通配的功能;
语法结构:
grep [OPTIONS] PATTERN [FILE…] PATTERN 模式
grep [OPTIONS] [-e PATTERN | -f FILE] [FILE…]
命令选项:
–color=auto | 对匹配到的文本着色后高亮显示; |
---|---|
-i | ignorecase,忽略字符的大小写; |
-o | 仅显示匹配到的字符串本身; |
-v | 显示不能被模式匹配到的行; |
-E | 支持使用扩展的正则表达式元字符; |
-q | 静默模式,即不输出任何信息; |
-n | 显示行号 |
-A# | 后#行 |
-B# | 前#行 |
-C# | 前后各#行 |
将grep设置为默认高亮显示
前后指定行显示
基本正则表达式元字符
- 字符匹配
- 匹配次数
- 位置锚定
- 分组及引用
字符匹配:
. :匹配任意单个字符; 类似glob中的? Grep "r..t" /etc/passwd
[]:匹配指定范围内的任意单个字符;
[^]:匹配指定范围外的任意单个字符; 脱字符
[:digit:]数字
[:lower:]小写字母
[:upper:]大写字母
[:alpha:]所有字母
[:alnum:]数字和字母
[:punct:]所有标点符号
[:space:] 空格
匹配次数:
用在要指定其出现的次数的字符的后面,用于限制其前面字符出现的次数;
默认工作于贪婪模式;
*:匹配其前面的字符任意次;0,1,多次;例如:grep "x*y"
创建文本test1
?:匹配其前面的字符0次或1次;即其前面的字符是可有可无的;
+:匹配其前面的字符1次或多次;即其面的字符要出现至少1次;
前面的无法控制次数,我们还可以精确次数匹配
\{m\}:匹配 其前面的字符m次; Grep "x\{1\}y"
\{m,n\}:匹配其前面的字符至少m次,至多n次;
\{0,n\} :至多n次
\{m,\} :至少m次
一个x
至少2个x
位置锚定:
^:行首锚定;用于模式的最左侧; 脱字符
Grep "^root" /etc/passwd
$:行尾锚定;用于模式的最右侧; Grep "root$" /etc/passwd
^PATTERN$:用于PATTERN来匹配整行;
^$:空白行;
^[[:space:]]*$:空行或包含空白字符的行;
5.8 Linux文件搜索命令
5.8.1 which 查找可执行的文件
在PATH变量指定的路径中,搜索某个系统命令的位置,并且返回第一个搜索结果。
也就是说,使用which命令,就可以看到某个系统命令是否存在,
以及执行的到底是哪一个位置的命令.
单词:非特殊字符组成的连续字符(字符串)都称为单词;
\< 或\b:词首锚定,用于单词模式的左侧; Grep "\<root" /etc/passwd
\> 或\b:词尾锚定,用于单词模式的右侧; Grep "root\>" /etc/passwd
\<PATTERN\>:匹配完整单词; Grep "\<root\>" /etc/passwd
练习:
1、显示/etc/passwd文件中不以/bin/bash结尾的行;
2、找出/etc/passwd文件中的两位数或三位数;
分组及引用
\(\):将一个或多个字符捆绑在一起,当作一个整体进行处理;
\(xy\)*ab 命令行中括号有特殊意义所以用转义符\
Note:分组括号中的模式匹配 到的内容会被正则表达式引擎自动记录于内部的变量中,
这些变量为:
\1:模式从左侧起,第一个左括号以及与之匹配的右括号之间的模式所匹配到的字符;
\2:模式从左侧起,第二个左括号以及与之匹配的右括号之间的模式所匹配到的字符;
\3
. ..
创建一个文件txt
找到前后一致的单词例如同事love 或者同是like l…e