grep、egrep、fgrep命令和正则表达式用法

一、简介

1.1、grep说明

grep命令简单来说就是linux系统实现文本内容筛选过滤的命令。当我们需要快速定位查找文本(通常是配置文件)中我们需要的内容时,使用grep 命令绝对算是最有效的处理方式之一。原因就在于grep可以配合包括“管道”、“正则表达式”等命令完成我们想要的关键字筛选过滤功能。个人认为不管是喜 欢Linux系统的发烧友,还是DBA、程序员、运维人员、架构师、项目经理等,熟练运用掌握grep命令都是必不可少的。比如在日常工作中令开发人员很 头大的事情就是在查看tomcat中项目运行生成的日志文件,这些日志文件通常内容都非常之多,而快速定位到日志里面的异常错误提示信息是必不可少的,这 种情况下其中一种解决方案就是采用grep命令来定位查找输出关键信息(当然还有更多其他不错的解决方案)。

1.2、正则表达式说明

正则表达式(英文:Regular Expression)简单来说就是一种按特定要求定义的符合某种语法规则语义的字符串。采用正则表达式可以帮助我们实现过滤、筛选等常见功能。例如它可 以轻松完成校验电话、邮箱格式是否正确、url拦截匹配等常用功能,减少了一系列不必要的条件判断,从而提升工作效率。从实用性角度来说,不管是在 linux系统中配合grep命令实现关键字查找匹配,还是数据库编写sql语句,甚至服务端及前端校验数据安全性等方面都离不开正则表达式,它几乎可以 说是IT从业人士必须要理解掌握的关键技术。

二、用法

首先grep是bash中非常好用的命令,虽然不是系统内置命令,不过一般的linux系统安装完成之后都会自带这个命令。grep命令常见用法有三种,分别是grepegrepfgrep。下面分别介绍如下三种。

2.1、grep 使用格式如下(关键参数标红):

grep [OPTIONS] PATTERN [FILE…]

grep [OPTIONS] [-e PATTERN | -f FILE] [FILE…]

例1:实现在passwd文件中搜索root用户并把搜索结构显示出来的关键字标红,命令如下:

grep –color=auto "root" /etc/passwd

效果如下图:

例2:只显示匹配到的关键字,不显示其他内容,命令如下:

grep –color=auto -o "root" /etc/passwd

效果如下图:

例3:如果想一直显示关键字标红功能,可以定义别名,保证长期有效,如当前root用户永久生效此配置,

设置方式如下图:

例4:搜索结果出现的关键字忽略字母大小写,命令如下:

grep -i "root" /etc/passwd

效果如下图:

例5:实现搜索结果取反操作(显示为非匹配的搜索结果),命令如下:

grep -v "abc" test.txt

效果如下图:

例6:搜索结果显示行号,命令如下:

grep -n "ab" text.txt

效果如下图:

例7:查找出匹配的搜索结果前n行、后n行或前后n行,命令如下:

grep -A 2 "AbC" text.txt

grep -B 2 "AbC" text.txt

grep -C 2 "AbC" text.txt

效果如下图:

例8:grep命令不仅可以查找文本匹配内容,文件夹和文件也能通过grep配合管道实现查找,命令如下:

2.2、grep配合正则表达式

2.2.1、字符匹配

例1:(正则表达式.) 搜索匹配任意单个字符,命令如下:

grep "a.c" test.txt

效果如下图:

例2:(正则表达式[])搜索指定范围匹配的任意单个字符,命令如下:

grep "[ad]" test.txt

效果如下图:

例3:(正则表达式[^])搜索指定范围匹配的任意单个字符,命令如下:

grep "[^ad]" test.txt

效果如下图:

例4:(正则表达式[0-9]或[[:digit:]])搜索指定数字范围内匹配到的结果,命令如下:

grep "[0-9]" test.txt 或 grep "[[:digit:]]" test.txt

效果如下图:

例5:(正则表达式[a-z]或[[:lower:]])搜索指定小写字母范围内匹配到的结果,命令如下:

grep "[a-z]" test.txt 或 grep "[[:lower:]]" test.txt

效果如下图:

例6:(正则表达式[A-Z]或[[:upper:]])搜索指定大写字母范围内匹配到的结果,命令如下:

grep "[A-Z]" test.txt 或 grep "[[:upper:]]" test.txt

效果如下图:

例7:(正则表达式[[:space:]])搜索匹配单行包含空格的内容,命令如下:

grep "[[:space:]]" test.txt

效果如下图:

例8:(正则表达式[[:punct:]])搜索匹配单行包含标点符号的内容,命令如下:

grep "[[:punct:]]" test.txt

效果如下图:

例9:(正则表达式[[0-9a-z-A-Z]]或[[:alnum:]])搜索匹配单行包含数字和大小写字母的内容,命令如下:

grep "[[0-9a-zA-Z]]" test.txt 或 grep "[[:alnum:]]" test.txt

效果如下图:

例10:(正则表达式[[a-z-A-Z]]或[[:alpha:]])搜索匹配单行包含大小写字母的内容,命令如下:

grep "[[a-zA-Z]]" test.txt 或 grep "[[:alpha:]]" test.txt

效果如下图:

2.2.2、次数匹配

例1:(正则表达式*)搜索匹配单行*左侧的任意长度的字符,包含0次1次或多次,命令如下:

grep "a*" test.txt

效果如下图:

例2:(正则表达式.*)搜索匹配单行任意长度的任意字符,包含0次1次或多次,属于贪婪模式,命令如下:

grep "a.*" test.txt

效果如下图:

例3:(正则表达式\?)搜索匹配单行\?左侧字符出现0次或1次,命令如下:

grep "d\?" test.txt

效果如下图:

例4:(正则表达式\+)搜索匹配单行\+左侧字符至少出现1次,命令如下:

grep "a\+" test.txt

效果如下图:

例5:(正则表达式\{m\})搜索匹配单行\{m\}左侧字符精确出现m次,命令如下:

grep "a\{2\}" test.txt

效果如下图:

例6:(正则表达式\{m,n\})搜索匹配单行\{m,n\}左侧字符至少出现m次,至多出现n次,命令如下:

grep "a\{1,2\}" test.txt

效果如下图:

例7:(正则表达式\{0,n\})搜索匹配单行\{0,n\}左侧字符最多出现n次,命令如下:

grep "a\{0,2\}" test.txt

效果如下图:

例8:(正则表达式\{m,\})搜索匹配单行\{m,\}左侧字符至少出现m次,命令如下:

grep "a\{m,\}" test.txt

效果如下图:

2.2.3、位置锚定

例1:(正则表达式^)搜索匹配单行锚定行首内容,命令如下:

grep "^a" test.txt

效果如下图:

例2:(正则表达式$)搜索匹配单行锚定行尾内容,命令如下:

grep "c$" test.txt

效果如下图:

例3:(正则表达式^$)搜索匹配空白行内容,命令如下:

grep "^$" test.txt

效果如下图:

例4:单词锚定:

(正则表达式\<)实现锚定词首,也可以用\b实现同样效果

(正则表达式\>)实现锚定词尾,也可以用\b实现同样效果

命令如下:

grep "\<12" test.txt 或 grep "\b12" test.txt

grep "test\>" test.txt 或 grep "test\b" test.txt

效果如下图:

整个单词锚定:

(正则表达式\<…\>)实现锚定整个词,也可以用\b实现同样效果

命令如下:

grep "\<456test\>" test.txt 或 grep "\b456test\b" test.txt

效果如下图:

例5:分组锚定:

(正则表达式\(\))实现分组锚定,分组匹配到的结果字符,自动被grep记忆在内置变量中,这些变量分别是\1、\2 …并且这些变量可以再次被使用。

\1: 引用,在该模式中自左而右,获取由第一个左括号以及与之对应的右括号中的模式所匹配到的内容。

\2: 引用,在该模式中自左而右,获取由第二个左括号以及与之对应的右括号中的模式所匹配到的内容。

命令如下:

grep "\(123\)" test.txt

grep "\(123\).*\1" test.txt

grep "\(456\)….\1\(789\)\2" test.txt

效果如下图:

2.2.4、egrep 使用说明

egrep使用格式与grep基本相同(可使用grep -E command实现同样效果),不过egrep只支持扩展的正则表达式,不支持基本正则表达式。

命令:egrep PATTERN FILE… 或 grep -E PATTERN FILE…

egrep支持如下用法:

字符匹配模式如下:

.

[]

[^]

次数匹配模式如下:

*: 任意次

?:0或1次

+: 至少1次

{m}:精确匹配m次;

{m,n}:至少m次,至多n次;

{m,}:至少m次;

{0,n}:至多次;

位置锚定模式如下:

^

$

\<, \b

\>, \b

分组匹配模式如下:

()

引用:\1, \2, …

或者匹配支持如下:

a|b:a或b 或两侧的所有内容;

egrep或者匹配示例:

(正则表达式|)实现或者匹配,命令如下:

egrep "456|789" test.txt 或 grep -E "456|789" test.txt

效果如下图:

2.2.5、fgrep 使用说明

fgrep不支持正则表达式,只能实现全部关键字匹配,个人感觉实际工作中不太常用。

fgrep示例:

fgrep "abdc" test.txt

效果如下图:

三.结尾总结

grep以及相关正则表达式是linux系统中日常工作开发必须掌握的命令。egrep实现功能基本与grep相同,只是写法稍有不同,可根据个人习惯选择采用grep或egrep命令。fgrep因为不支持正则表达式,因此很少使用。

原文发布于微信公众号 - 马哥Linux运维(magedu-Linux)

原文发表时间:2015-10-06

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏漏斗社区

CTF| SQL注入之login界面

SQL注入是CTF WEB方向必不可少的一种题型,斗哥最近也做了一些在线题目,其中最常见的题目就是给出一个登录界面,让我们绕过限制登录或者一步步注入数据。 万...

2K8
来自专栏owent

小记最近踩得两个C++坑

记一下最近踩得两个C++独有的暗坑,其中一个和ABI相关。第二个坑其实之前研究过,但是没有实例,这次算是碰到了个典型的实例。

1032
来自专栏对角另一面

lodash源码分析之chunk的尺与刀

以不正义开始的事情,必须用罪恶使它巩固。 ——莎士比亚《麦克白》 最近很多事似乎印证了这句话,一句谎言最后要用一百句谎言来圆谎。 本文为读 lodash...

2260
来自专栏java一日一条

你应该学习正则表达式

Regular Expressions (Regex):正则表达式,软件工程中最为强大,且广泛适用,令人信服的技术之一。从验证电子邮件地址到执行复杂的代码重构器...

1152
来自专栏牛客网

知识总结:设计模式总结(C++和Python实现)前言案例实现 创建型模式 结构型模式行为型模式对比总结

前言 GoF的23种设计模式,包括创建型、结构型和行为型,其涵盖了面向对象思想的精髓以及诸多细节。本文结合《设计模式》和《大话设计模式》,并用C++和Pytho...

5628
来自专栏王磊的博客

如何让nodejs同步操作

众所周知,异步是nodejs中得天独厚的特点和优势,但同时在程序中同步的需求(比如控制程序的执行顺序为:func1 -> func2 ->func3 )也是很常...

2989
来自专栏拂晓风起

【超精简JS模版库/前端模板库】原理简析 和 XSS防范

1433
来自专栏猿人谷

linux时间相关结构体和函数整理

一、时间类型。Linux下常用的时间类型有4个:time_t,struct timeb, struct timeval,struct timespec,cloc...

2265
来自专栏程序员与猫

Go Code Review Comments 译文(截止2018年7月27日)

持续更新中… 原文最新链接 https://github.com/golang/go/wiki/CodeReviewComments/5a40ba36d38...

1303
来自专栏Golang语言社区

再谈谈获取 goroutine id 的方法

去年年初的时候曾经写过一篇关于如何获取goroutine id的方法: 如何得到goroutine 的 id?, 当时调研了一些一些获取goid的方法。基本的方...

3937

扫码关注云+社区