Linux行处理工具之grep?正则表达式详解(grep用法详解:grep与正则表达式)太疯狂了

随心笔谈2年前发布 编辑
180 0
🌐 经济型:买域名、轻量云服务器、用途:游戏 网站等 《腾讯云》特点:特价机便宜 适合初学者用 点我优惠购买
🚀 拓展型:买域名、轻量云服务器、用途:游戏 网站等 《阿里云》特点:中档服务器便宜 域名备案事多 点我优惠购买
🛡️ 稳定型:买域名、轻量云服务器、用途:游戏 网站等 《西部数码》 特点:比上两家略贵但是稳定性超好事也少 点我优惠购买



目录正则表达式在grep应用以及差别匹配案例fgrep总结

之前我们学习了的基本操作,以及提及了的孪生兄弟,这次我们来看下。

在介绍正则表达式之前,我们先来尝试一下,假如有如下文本。

我们想获取空行,应该如何来写呢?

命令:

grep ^$ test1 -n

通过上述例子,我们使用正则表达式已经成功拿到了第四行数据,那么,这究竟如何解呢,我们细看博文。

表达式有三种不同的版本,分别为() 、() 以及 () ,我们默认支持的是,而是支持的,或者说是支持的, 而则是支持的,那么这三者究竟有啥区别呢?

BREEREPCRE任意字符…前一个字符0次或者出现1次???前一个字符出现0次或无数次***前一个字符出现一个或者更多+++字符集[…][…][…]字符集取反[^…][^…][^…]匹配前面字符出现的n次{n}{n}{n}匹配前面字符出现的n次以上{n,}{n,}{n,}匹配前面字符出现的n次到m次{n,m}{n,m}{n,m}开头结尾$$$多表达式连接|单词\w\w\w 或者 [[:word:]]字母大写/小写[[:upper:]]/[[:lower:]][[:upper:]]/[[:lower:]][[:upper:]]/[[:lower:]]非单词\W空白字符\s 或者 [[:space:]]\s 或者 [[:space:]]非空白字符[^[:space:]][^[:space:]]\S数字\d 或者 [[:digit:]][[:digit:]][[:digit:]]非数字\D[^[:digit:]][^[:digit:]]

那么如何进行切换呢? 如上面所示,我们来看下。

如上所述,若我们需要连接多个匹配项,在中则是,而在和中则是,所以我们可以顺利获取出结果,更多匹配项如上所述

匹配电话号码

若电话号码为类型的,如何进行匹配呢? 我们可以使用进行匹配。

例如:

命令:

echo “telphone: 180-1234-5678” | grep ‘[0-9]{3}-[0-9]{4}-[0-9]{4}’ -o

同样的,该方法还可以用来匹配其地址,正则:

匹配空行

若我们想匹配空行,则可以使用进行匹配,即: 开头就是结尾。

例如:

如上命令,我们顺利取出了 第3、5、6行数据

匹配所有字母

命令:

echo ‘Ac123e23dddwQW21’ | grep “[[:upper:]]|[[:lower:]]” -o

取出在使用的配置文件

我们知道服务器是以来注释的,我们可以利用或者来过滤掉注释和空格,例如:

最为简单,它不会启用正则表达式,而是按照字符来进行搜索,什么意思呢? 我们举个小案例就清楚了,

它不会进行任何正则匹配,所以可以直接使用搜索选就成,不用考虑转移啥的。

我们一般将称之为 基本正则表达式、称之为 扩展正则表达式 而 称之为兼容的正则表达式,如上正则表达式不是工具所实现的,而是单独的一套表达式,有很多语言在使用中,例如 默认正则表达式是 , 而我们之前所学习的使用的正则表达式则是,是不是感觉知识被串联起来了呢,好巧,我也是,怎么样,快来动手试验一下吧。

到此这篇关于Linux行处理工具之grep 正则表达式详解的文章就介绍到这了,更多相关linux grep 正则表达式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:linux下关于正则表达式grep的一点总结linux 正则表达式grep实例分析linux grep与正则表达式使用介绍linux系统用户管理与grep正则表达式示例教程浅谈Linux grep与正则表达式linux grep正则表达式与grep用法详解

© 版权声明

相关文章