扩展正则表达式
grep 命令仅支持基础正则表达式,如果使用扩展正则表达式,需要使用 egrep 或 awk 命令。这里我们直接使用 egrep 命令。egrep 命令与 grep 命令的用法基本相似。egrep 命令是一个搜索文件获得模式,使用该命令可以搜索文件中的任意字符串和符号,也可以搜索一个或多个文件的字符串,一个提示符可以是单个字符、一个字符串、一个字或一个句子。
1.与基础正则表达式类型相同,扩展正则表达式也包含多个元字符,常见的扩展正则表达式的元字符主要包括以下几个:
| 元字符 | 作用 |
| + | 重复一个或者一个以上的前一个字符 |
| ? | 零个或者一个的前一个字符 |
| | | 使用或者(or)的方式找出多个字符 |
| () | 查找“组”字符串 |
| ()+ | 辨别多个重复的组 |
2.具体操作
(1)+
示例:执行“egrep -n 'wo+d' test.txt”命令,即可查询"wood" "woood" "woooooood"等字符串

(2)?
示例:执行“egrep -n 'bes?t' test.txt”命令,即可查询“bet”“best”这两个字符串

(3)|
示例:执行“egrep -n 'of|is|on' test.txt”命令即可查询"of"或者"if"或者"on"字符串

(4)()
示例:“egrep -n 't(a|e)st' test.txt”。“tast”与“test”因为这两个单词的“t”与“st”是重复的,所以将“a”与“e”列于“()”符号当中,并以“|”分隔,即可查询"tast"或者"test"字符串

(5)()+
示例:“egrep -n 'A(xyz)+C' test.txt”。该命令是查询开头的"A"结尾是"C",中间有一个以上的 "xyz"字符串的意思

注意:()里的字符串顺序要和文件中的顺序要一致,如果写为(yxz),是查不出来的。
egrep命令用于支持扩展正则表达式,它与grep类似但提供更多的元字符功能,如+、?、|和()。通过这些元字符,可以更精确地匹配文件中的字符串。例如,'+'匹配一个或多个前一个字符,'?'匹配零或一个前一个字符,'|'用于选择性匹配,而'()'则用于分组。示例中展示了如何使用这些元字符进行字符串查询。
1658

被折叠的 条评论
为什么被折叠?



