正则表达式扩展应用

使用扩展正则表达式 egrep

首先来看一条前面章节学习过的用来去除空白行和注释行的指令:

bash 复制代码
grep -v '^$' regular_express.txt |grep -v '^#'

可见,通常的 grep 指令需要使用两次管线命令。那么如果使用扩展正则表达式,则可以简化为:

bash 复制代码
egrep -v '^$|^#' regular_express.txt

利用支持扩展正则表达式的 egrep 与特殊字符 | 的组合功能来间隔两组字符串,如此一来,可以极大地化简指令。

此外,也可以使用 grep -E 来使用扩展正则表达式,不过一般更建议直接使用 egrepgrep -Eegrep 之间类似命令别名的关系。

扩展规则(一)

回忆一下,在非扩展正则表达式中,我们使用 * 来表示任意个重复字符(零至无穷多个):

bash 复制代码
grep -n 'goo*d' regular_express.txt

在扩展正则表达式中,则可以进一步细分为一个或一个以上零个或一个字符:

+ 表示重复一个或一个以上的前一个字符
bash 复制代码
egrep -n 'go+d' regular_express.txt
? 表示重复零个或一个的前一个字符
bash 复制代码
egrep -n 'go?d' regular_express.txt

执行上述三条指令,比较三者的不同。

扩展规则(二)

| 表示用或(or)的方式找出数个字符串

查找 gd 或 good:

bash 复制代码
egrep -n 'gd|good' regular_express.txt
() 表示找出组字符串

查找 glad 或 good,注意到由于二者存在重复字母,所以可以将其合并:

bash 复制代码
egrep -n 'g(la|oo)d' regular_express.txt
()+ 多个重复群组判别

查找开头是 A 结尾是 C 中间有一个以上的 xyzxz 字符串:

bash 复制代码
echo 'AxyzxyzxyzxyzC'|egrep 'A(xyz)+C'
​
echo 'AxyzxyzxyzxyzC'|egrep 'A(xz)+C'

结果显示 A(xyz)+C 可以匹配,A(xz)+C 没有匹配项。

至此,关于正则表达式的基本知识就介绍完了,希望同学们多加练习,最终能够熟练地运用所学的关于正则表达式的知识,达到简化字符串处理的目的。

相关推荐
Dovis(誓平步青云)7 小时前
《内核视角下的 Linux 锁与普通生产消费模型:同步原语设计与性能优化思路》
linux·运维·性能优化
xu_yule7 小时前
Linux_13(多线程)页表详解+轻量级进程+pthread_create
linux·运维·服务器
江湖有缘9 小时前
Linux系统之htop命令基本使用
linux·运维·服务器
CodeByV9 小时前
【Linux】基础 IO 深度解析:文件、描述符与缓冲区
linux
xu_yule15 小时前
Linux_12(进程信号)内核态和用户态+处理信号+不可重入函数+volatile
linux·运维·服务器
虾..15 小时前
Linux 环境变量&&进程优先级
linux·运维·服务器
i***t91915 小时前
Linux下MySQL的简单使用
linux·mysql·adb
偶像你挑的噻15 小时前
11-Linux驱动开发-I2C子系统–mpu6050简单数据透传驱动
linux·驱动开发·stm32·嵌入式硬件
稚辉君.MCA_P8_Java16 小时前
DeepSeek 插入排序
linux·后端·算法·架构·排序算法
郝学胜-神的一滴18 小时前
Linux命名管道:创建与原理详解
linux·运维·服务器·开发语言·c++·程序人生·个人开发