我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Linux行处理工具之grep 正则表达式详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Linux行处理工具之grep 正则表达式详解

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

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

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

命令:

grep ^$ test1 -n

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

正则表达式在grep应用以及差别

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

 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:]]

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

如上所述,若我们需要连接多个匹配项,在BRE(grep)中则是|,而在ERE(egrep)PCRE(grep -P)中则是|,所以我们可以顺利获取出结果,更多匹配项如上所述

匹配案例

匹配电话号码

若电话号码为xxx-xxxx-xxxx类型的,如何进行匹配呢? 我们可以使用'[0-9]{3}-[0-9]{4}-[0-9]{4}'进行匹配。

例如:

命令:

echo "telphone: 180-1234-5678" | grep  '[0-9]{3}-[0-9]{4}-[0-9]{4}' -o

同样的,该方法还可以用来匹配其ip地址,正则: [0-9]{0,3}.[0-9]{0,3}.[0-9]{0,3}.[0-9]{0,3}

匹配空行

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

例如:

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

匹配所有字母

命令:

echo 'Ac123e23dddwQW21' | grep "[[:upper:]]|[[:lower:]]" -o

取出redis在使用的配置文件

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

fgrep

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

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

总结

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

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Linux行处理工具之grep 正则表达式详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Linux行处理工具之grep 正则表达式详解

grep表达式有三种不同的版本,分别为basic(BRE) 、extended(ERE) 以及 perl PCRE,这篇文章主要介绍了Linux行处理工具之grep 正则表达式详解,需要的朋友可以参考下
2022-11-13

Centos7 Shell编程之正则表达式、文本处理工具详解

正则表达式可以很灵活的提供各种模糊匹配的筛选规则。常被用来检索、替换那些符合某个模式的文本,这篇文章主要介绍了Centos7 Shell编程之正则表达式、文本处理工具,需要的朋友可以参考下
2022-11-13

linux文本处理工具及正则表达式集锦

cat命令:查看文本内容cat [选项]... [文件]...-E 显示行结束符-n 显示文本内容时显示行号-A 显示所以控制符-b 非空行编号-s 压缩连续的空行成一行[root@bogon ~]# cat
2022-06-04

详解Linux--shell脚本之正则表达式

一、正则表达式的概念及特点:正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。规定一些特殊语法表示字符类、数量限定符和位置
2022-06-04

linux文本处理工具及正则表达式的示例分析

这篇文章主要介绍linux文本处理工具及正则表达式的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!cat命令:查看文本内容 cat [选项]... [文件]... -E
2023-06-09

PHP Linux脚本操作经验分享:利用正则表达式进行文本处理

正则表达式是处理文本的强大工具,能够快速而灵活地匹配、搜索和替换文本中的模式。在PHP Linux脚本编程中,利用正则表达式进行文本处理常常是必不可少的技能。本文将分享一些实用的正则表达式操作技巧,并提供具体的代码示例供参考。匹配和提取文本
2023-10-21

PHP Linux脚本开发经验分享:利用正则表达式进行字符串处理

在Linux环境下使用PHP脚本进行开发是一种常见的方式。而在脚本的开发过程中,字符串处理往往是一个非常重要的部分。而正则表达式作为一种强大的字符串匹配工具,能够帮助我们更高效地进行字符串处理。本文将分享一些在Linux环境下使用PHP脚本
2023-10-21

编程热搜

目录