grep的使用和正则表达式

       grep作为Linux中的文本编辑的三剑客之一,它的功能很强大,并不是虚传,学会了grep在文本中找我们要找的的字符串总是能很轻易地找到,grep不仅仅就这一点功能,它在我们工作上也会对我们有很大的帮助。下面我来介绍一下grep的简单的功能。

grep :文本过滤( 模式:pattern) 工具; (以行为单位的)

grep, egrep,[fgrep (不支持正则表达式 搜索) 搜索速度快]

grep: Global search REgular expression and Print outthe line.

作用:文本搜索工具,根据用户指定的“模式”对目标文本逐行进行匹配检查;打印匹配到的行;

模式:由正则表达式字符及文本字符所编写的过滤条件

grep [OPTIONS] PATTERN [FILE…]

grep root /etc/passwd

grep "$USER" /etc/passwd

grep '$USER' /etc/passwd

grep `whoami` /etc/passwd

grep 命令选项

–color=auto:  对匹配到的文本着色显示;

-v:  显示不能够被pattern 匹配到的行;

grep的使用和正则表达式

-i:  忽略字符大小写

grep的使用和正则表达式

-n: : 显示匹配的行号

grep的使用和正则表达式

-c:  统计匹配的行数

grep的使用和正则表达式

-o:  仅显示匹配到的字符串;

grep的使用和正则表达式

-q:  静默模式,不输出任何

-A # :after,  后#行

-B #: before,  前#行

-C # :context,  前后各#行

-e :实现多个选项间的逻辑or (或)关系   -C # :conte

grep –e ‘cat ’ -e ‘dog’ file

grep的使用和正则表达式

-w :整行匹配整个单词

grep -w.PNG

-E :使用ERE

正则表达式引擎:

采用 不同 算法,检查处理正则表达式的软件模块

PCRE(Perl Compatible Regular Expressions)

元字符分类:字符匹配、匹配次数、位置锚定、分组

man 7 regex

程序支持:grep, vim, less,nginx等

分两类:

基本正则表达式:BRE

字符匹配:

. :  匹配任意单个字符;

[] :  匹配指定范围内的任意单个字符

[].PNG

[^]  :匹配指定范围外的任意单个字符

[^].PNG

[:digit:] 、[:lower:] 、[:upper:] 、[:alpha:] 、[:alnum:] 、[:punct:] 、[:space:]

匹配次数:用在要指定次数的字符后面,用于指定前面的字符要出现的次数

* :匹配前面的字符任意次,包括0次

贪婪模式:尽可能长的匹配

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

匹配任意单个字符.PNG

\? :匹配其前面的字符0 或1次

\+ :匹配其前面的字符至少1次

匹配前面的字符至少一次.PNG

\{n\} :匹配前面的字符n次

匹配前面字符n次.PNG

\{m,n\} :匹配前面的字符至少m 次,至多n次

匹配前面的字符至少m次,至多n次.PNG

\{,n\} :匹配前面的字符至多n次

匹配前面的字符至多n次.PNG

\{n,\} :匹配前面的字符至少n次

匹配前面的字符至少n次.PNG

位置锚定:定位出现的位置

^ :行首锚定,用于模式的最左侧

$ :行尾锚定,用于模式的最右侧

词手和词尾锚定.PNG

^PATTERN$:  用于模式匹配整行

^$:  空行

^[[:space:]]*$  :空白行

\< 或 或 \b :词首锚定,用于单词模式的左侧

\> 或 或 \b :词尾锚定;用于单词模式的右侧

\<PATTERN\> :匹配整个单词

匹配整个单词.PNG

分组:\(\) :将一个或多个字符捆绑在一起,当作一个整体进行处理,如:\(root\)\+

\(root\) \+ 表示root多次

分组括号中的模式匹配到的内容会被正则表达式引擎记录于内部的变量中,这些变量的命名方式为: \1, \2, \3, …

\1:  从左侧起,第一个左括号以及与之匹配右括号之间的模式所匹配到的字符;

实例: \(string1\+\(string2\)*\)

\1: string1\+\(string2\)*

\2: string2v

没有指定你要匹配的位置,它会把这一列中都符合的显示出来

捕获2.PNG

当你指定要匹配的位置后,但指定位置中出现了你要匹配的字符 ^\<\(.*\)\> 只是你匹配的字符的一部分,它也会把要配备的显示出来。这是需要你在你匹配的字符\1 前面加上一个/\1符号或者\<\1\>就行了。

捕获3.PNG

后向引用:引用前面的分组括号中的模式所匹配字符(而非模式本身)

正则表达式图表

grep的使用和正则表达式

grep的使用和正则表达式

REGEXP :由一类特殊字符及文本字符所编写的模式,其中有些字符(元字符)不表示字符字面意义,而表示控制或通配的功能

扩展正则表达式:ERE

grep -E, egrep

egrep 及扩展的正则表达式

egrep = grep -E

egrep [OPTIONS] PATTERN [FILE…]

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

字符匹配:

.  任意单个字符

[]  指定范围的字符

[^]  不在指定范围的字符

次数匹配:

* :匹配前面字符任意次

egrep 匹配前面字符任意次.PNG

?: 0 或1次

egrep 匹配前面的字符0或1次.PNG

+ :1 次或多次

egrep 匹配前面字符一次或多次.PNG

{m} :匹配m次

egrep 匹配m次.PNG

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

egrep  匹配前面的字符至少m,至多n.PNG

位置锚定:

^ : 行首

$ : 行尾

\<, \b : 语首

\>, \b : 语尾

egrep 词首词尾锚定.PNG

分组:

()后向引用:\1, \2, …

或者:

a|b

C|cat: C 或cat

(C|c)at:Cat 或cat

egrep 分组.PNG

原创文章,作者:AN0519,如若转载,请注明出处:http://www.178linux.com/31467

(0)
AN0519AN0519
上一篇 2016-08-10 10:27
下一篇 2016-08-10 10:27

相关推荐

  • 优云软件数据专家最佳实践:数据挖掘与运维分析

    这份研究报告,作者是优云软件数据专家陈是维,在耗时1年时间制作的一份最佳实践,今天和大家分享下,关于《数据采矿和运维分析》,共同探讨~ 数据挖掘(Data Mining)是从大量数据中提取或“挖掘”知识。 广义数据挖掘:数据挖掘是从存放在数据库、数据仓库或其它信息库中的大量数据挖掘有趣知识的过程。 数据挖掘技术侧重:1)概率与数理统计 2)数据库技术 3)人…

    大数据运维 2016-07-16
  • 文本处理工具Sed及VIM的使用

    1.文本处理工具Sed   Stream Editor 行编辑器                            图1-1 sed帮助手册  用法:      se…

    Linux干货 2016-08-10
  • 常用的MySQL数据库备份

    常用的MySQL数据库备份方式 前言 为什么需要备份数据? 数据的备份类型 MySQL备份数据的方式 备份需要考虑的问题 设计合适的备份策略 实战演练 使用cp进行备份 使用mysqldump+复制BINARY LOG备份 使用lvm2快照备份数据 使用Xtrabackup备份 总结 前言 我们试着想一想, 在生产环境中什么最重要?如果我们服务器的硬件坏了可…

    2015-06-13
  • LINUX基础知识

    计算机的组成及其功能。 现代计算机体系将计算机分为控制器、运算器、存储器、输入设备和输出设备5个部分 *控制器:控制器是整个计算机的中枢神经,其功能是对程序规定的控制信息进行解释,并根据具体要求进行控制、调度程序、数据、地址,协调计 算机各个部分工作,协调计算机各部分工作及内存、IO设备等的访问 *运算器:运算器是对数据进行各种算数运算和逻辑运算也就是对数据…

    Linux干货 2018-02-25
  • CentOS6.9系统上编译安装httpd.2.2.32

    本文所做的所有操作是在一部新安装的CentOS6.9系统上。 1.环境与配置 环境说明:VMware上安装的CentOS6.9系统,两张系统盘做成的yum源 配置:编译生成的所有的文件都存放在/usr/local/httpd22/这个目录下 2.安装GCC编译器 [root@localhost ~]# yum grouplist | grep “Develo…

    2017-04-20
  • Linux网络属性管理(二)

    Linux网络属性(二) Linux 网络属性管理(二) ip命令 ip – show / manipulate routing, devices, policy routing and tunnels ip [ OPTIONS …

    Linux干货 2016-07-07