egrep及扩展正则表达式 与正则表达式不同处

egrep及扩展正则表达式与正则表达式不同处

正则表达式有两类,分为基本正则表达式和扩展正则表达式,是使用命令egrep来使用扩展正则表达式,它与grep很多功能相同,仅在元字符上实现了些扩展扩展,在元字符的表示上与基本正则表达式略不同。

1.命令格式:

egrep [option] pattern file

2.命令功能:

用于过滤/搜索的特定字符。可使用扩展正则表达式能多种命令配合使用,使用上十分灵活。

3.命令参数:

 egrep等同于grep -E选项

扩展正则表达式的元字符:

字符匹配:

字符匹配:

.    #匹配单个非换行符的字符 如:‘gr.p‘匹配gr后接一个任意字符,然后是p。

[]   #匹配一个指定范围内的字符,如‘[Gg]rep‘匹配Grep和grep。

[^]  #匹配一个不在指定范围内的字符,如:‘[^A-FH-Z]rep‘匹配不包含A-R和T-Z的一个字母开头,紧跟rep的行。

次数匹配:

*    #匹配零个或多个先前字符。如:‘*grep‘匹配所有一个或多个空格后紧跟grep的行。

?  #匹配其前面出现的字符0次或1次。如:‘x\?y‘匹配x出现一次或者不出现的行。

+     #匹配其前面的字符出现至少一次。如:‘x\+y‘匹配x出现最少一次的行。

{m}  #匹配其前面的字符至少m次;如:‘0\{5\}‘匹配包含5个o的行。

{m,}  #重复字符x,至少m次,如:‘o\{5,\}‘匹配至少有5个o的行。

{m,n}:匹配其前面的字符至少m次,至多n次;o\{5,10\}‘匹配至少有5-10个o的行。

.* :匹配任意长度的任意字符

位置锚定:

$    #行尾锚定 如:‘grep$‘匹配所有以grep结尾的行。

^    #行首锚定 如:‘^grep‘匹配所有以grep开头的行。

^$   #空白行:行首与到行尾   特殊环境能用到

\<   #单词词首锚定,也可以用\b。如: ‘\<grep‘‘\bgrep‘只匹配grep单词开头的行。

\>   #词尾锚定,也可以用\b。如:‘grep/>‘‘grep/b‘只匹配grep单词结尾的行。

/<pattern/>  #单词锚定,只匹配出现pattern单词的行和‘/bpattern/b‘是一样的效果。

\b   #单词锁定符,如: ‘\bgrep\b‘只匹配grep。 同/<pattern/>

分组

()  #将关键字和元字符在里面分组,也支持后向引用。

后向引用:模式中,如果使用\(\)实现了分组,在某行文本的检查中,如果括号中的模式匹配到了某内容,次内容     后面的模式中可以被引用;\1,\2,\3   第一个括号,第二个括号,第三个括号模式自左而右,引用第#个左括号以及与其匹配右括号之间的模式匹配到的内容。

4.不同处:

紧紧在元字符表示上略有不同:

在次数匹配的:?,+,{m},{m,}{m,n},分组()等等元字符表示上略有不同,使用方法都是一样的,大家可以参考另一篇博文《grep命令及基本正则表达式》

时间: 2024-10-26 02:47:19

egrep及扩展正则表达式 与正则表达式不同处的相关文章

编程语言和shell编程的基础内容以及grep、egrep命令及相应的正则表达式和用法

bash的特性之多命令执行的逻辑关系: 1.命令替换(命令之间无明确的逻辑依赖关系) COMMAND1 $(COMMAND2) 2.管道(命令之间无明确的逻辑依赖关系) COMMAND1 | COMMAND2 | COMMAND3 前面的命令无论执行成功与失败后面命令继续执行:管道命令的前一个命令应该有标准和输出否则用":"隔开 例如:useradd sola :echo 456 | passwd --stdin sola 3.顺序执行结构 COMMAND1:COMMAND2:COMM

linux正则表达式和正则表达式的一些命令

正则表达式是处理一批繁杂的数据,做到快速搜索,快速匹配,快速替换删除等功能的一种需求.常用正则表达式的命令有grep,sed,awk(三剑客)vi,egrep.其中egrep和awk还支持扩展的正则表达式. 下面先介绍一下这些命令.vi和vim在以后介绍. grep: -v:排除匹配内容. -i:忽略大小写. -o:只输出匹配内容. -n:在行首显示行号. -e:扩展的正则表达式(=egrep). --color=auto:支持颜色. sed:输出时既输出匹配内容,还要把源内容原封不动得输出.

正则表达式与正则表达式在ios中的常见用法

一.什么是正则表达式 正则表达式,又称正规表示法,是对字符串操作的一种逻辑公式.正则表达式可以检测给定的字符串是否符合我们定义的逻辑,也可以从字符串中获取我们想要的特定部分.它可以迅速地用极简单的方式达到字符串的复杂控制. 二.正则表达式的语法 看一个过滤纯数字的例子 - (BOOL)validateNumber:(NSString *) textString{    NSString* number=@"^[0-9]+$";    NSPredicate *numberPre = [

Linux常用命令—egrep及扩展正则表达式

扩展正则表达式 扩展正则表达式命令:egrep 不支持正则表达式但是快速:fgrep 字符匹配: .: []: [^]: 次数匹配: *: ?: +:匹配其前面的字符至少一次 {m}:精确匹配 {m,n}无需反斜线: 位置锚定: ^: $: \<或者\b: \>或者\b: 分组: ():分组 \1,\2,\3,...... 或者 |:或(a|b) 例: C|cat=C或者cat (C|c)at=Cat或者cat 懒惰限定符 *?         重复任意次,但尽可能少重复 +?        

egrep 及扩展正则表达式

grep -E 表示支持扩展的正则表达式 grep -E = egrep 一.字符匹配: 扩展模式下的字符匹配与基本正则表达式的字符匹配相同,如: . 表示任意单个字符 [] 表示范围内人任意单个字符,如[0-9],表示任意单个数字 [^] 表示范围外的任意单个字符,如[^0-9],表示出数字外的任意单个字符 二.次数匹配: 上述字符匹配中,基本正则表达式与扩张表达式完全相同,但次数匹配就有些不一样了. * 匹配前面字符任意次,与基本正则表达式意义相同 ? 匹配其前字符0次或1次,其前面不需要

egrep和扩展正则表达式、条件表达式、算术运算

Linux05 Linux05_01?egrep使用和扩展正则表达式 REGEXP:REGular EXPression,其本身可能并不表示其本身的意思,而是做锚定等特殊意义的 Pattern: 由正则表达式元字符和字符组合起来用于过滤文本的过滤条件 正则表达式: Basic REGEXP:基本 Extended REGEXP:扩展 基本正则表达式: .: []: [^]: 次数匹配: *: \?: 0或1次 \{m,n\}:至少m次,至多n次: .*: 锚定: ^: $: \<, \b: \>

grep和egrep命令及相应的正则表达式用法总结

作为Linux上文本处理三剑客之一的文本搜索工具,grep和egrep是基于"pattern(模式)"对给定文本进行搜索操作. 正则表达式: 即 Regular Expression 缩写为REGEX. 是由一类特殊字符及文本字符所编写的模式,其有些字符不表示其字面意义,而是用于表示控制或通配的功能. 正则表达式分类: 基本正则表达式:BRE (Basic Regular Expression) 扩展正则表达式:ERE (Extend Regular Expression) 正则表达式

刨根究底正则表达式之一——正则表达式简介

声明: 本系列文章的主要参考书有: <精通正则表达式>英文版及中文版 作者: Jeffrey E·F·Friedl 译者:余晟 电子工业出版社 2012-07 <正则指引>作者:余晟 电子工业出版社 2012-05 <正则表达式必知必会>作者:Ben Forta 译者:杨涛 人民邮电出版社2015-01 <冒号课堂:编程范式与OOP思想>作者:郑晖 电子工业出版社 2009-10 同时,还参考了网上的大量资料,除了少部分资料由于未作大量修改(但基本上也有少量

Linux正则表达式-编写正则表达式

为了所有实用化的用途,你可以通过使用程序产生正确的结果.然而,并不意味着程序总是如你所愿的那样正确地工作.多数情况下,如果程序不能产生想要的输出,可以断定真正的问题(排除输入或语法错误)在于如何描述想要的东西. 换句话说,应该考虑纠正问题的地方是描述想要的结果的表达式.表达式不完整或者公式表示得不正确.例如,如果程序计算下面的表达式: PAY = WEEKLY_SALARY * 52 并知道这些变量的值,它将计算出正确的结果.但是有人会反对,因为公式没有说明销售人员,他也得到了一份佣金.所以为了