正则表达式与grep命令

前端之家收集整理的这篇文章主要介绍了正则表达式与grep命令前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

@H_301_1@一、引言

@H_301_1@介绍Linux@H_301_1@系统中的两个命名:grep@H_301_1@,egrep@H_301_1@。要想使用这2@H_301_1@个命令要先学会使用正则表达式,在介绍正则表达式之前,先说明一下,大家都熟知的在word@H_301_1@中使用的通配符,即:

*@H_301_1@:表示任意长度任意字符。

@H_301_1@?:表示任意单个字符。

@H_301_1@记住上面这两个字符所表示的意思,后面还会在正则表达式里出现,但意义不同。

1.@H_301_1@正则表达式:Regular Expression@H_301_1@,REGEXP

@H_301_1@由一类特殊字符及文本字符所编写的模式,其有些字符不表示字面意义,而是用于表示控制或通配功能

@H_301_1@元字符分两类:

@H_301_1@基本正则表达式:BRE

@H_301_1@扩展的正则表达式:ERE

@H_301_1@正则表达式引擎是利用正则表达式模式分析给定的文本的程序,在上亿单位的文本搜索时,有明显优势。

2.@H_301_1@三类grep@H_301_1@命令

@H_301_1@(1@H_301_1@)grep@H_301_1@:Global search REgular expression and Print out the line@H_301_1@;默认支持使用BRE@H_301_1@基本正则表达式;

@H_301_1@(2@H_301_1@)egrep@H_301_1@:支持使用扩展正则表达式;

@H_301_1@(3@H_301_1@)fgrep@H_301_1@:不支持使用正则表达式;

@H_301_1@二、grep@H_301_1@命令

@H_301_1@作用:文本搜索工具,根据用户指定的pattern@H_301_1@(过滤条件)对目标文本逐行进行匹配检查;打印出符合条件的行;

@H_301_1@模式:有文本字符及正则表达式元字符所编写的过滤条件;

1.@H_301_1@语法格式

grep [OPTIONS] PATTERN [FILE...]

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

2.@H_301_1@选项

--color=auto@H_301_1@:对匹配到的文本着色高亮显示

-i@H_301_1@:忽略字符大小写;

-o@H_301_1@:仅显示匹配到的文本自身;(默认显示匹配到的文本整行)

-v@H_301_1@,--invert-match@H_301_1@:反向匹配;

-E@H_301_1@,--extened-regexp@H_301_1@:支持扩展的正则表达式;相当于egrep@H_301_1@命令,对grep@H_301_1@和fgrep@H_301_1@有用;

-F@H_301_1@,--fixed-strings@H_301_1@:相当于fgrep@H_301_1@命令;

-q@H_301_1@,--quiet@H_301_1@,--silent@H_301_1@:静默模式,不输出任何信息;取命令执行状态码时常用;

-G@H_301_1@,--basic-regexp@H_301_1@:支持使用基本正则表达式,对egrep@H_301_1@和fgrep@H_301_1@有用;

-P@H_301_1@,--perl-regexp@H_301_1@:支持使用pcre@H_301_1@正则表达式(支持元字符很多,非常强大);

-e PATTERN@H_301_1@,--regexp=PATTERN@H_301_1@:使用多模式;

-f FILE@H_301_1@,--file=@H_301_1@:FILE@H_301_1@为每行包含了一个pattern@H_301_1@的文本文件,即grepscript@H_301_1@;把模式写在一个文件里,通过读取文件(脚本文件),来匹配;

-c@H_301_1@:显示统计匹配到的行数;

-r@H_301_1@,--recursive@H_301_1@:对目录下所有文件里的内容根据模式匹配;

-A #@H_301_1@,--after-context=#@H_301_1@:表示显示匹配到行的后面#@H_301_1@行;

-B #@H_301_1@,--before-context=#@H_301_1@:表示显示匹配到行的前面#@H_301_1@行;

-C #@H_301_1@,-#@H_301_1@,--context=#@H_301_1@:表示显示匹配到行的前后#@H_301_1@行;

@H_301_1@例如:

~]# grep 'root' /etc/passwd@H_301_1@:如果模式里有变量要用双引号;

~]# grep -v 'root' /etc/passwd@H_301_1@:反向匹配;

~]# grep -i 'root' /etc/passwd@H_301_1@:忽略字符大小写;

~]# grep -o 'root' /etc/passwd@H_301_1@:仅显示匹配到的文本自身;

~]# grep -q 'root' /etc/passwd@H_301_1@:静默模式;

~]# echo $?@H_301_1@;取命令执行状态码时常用;

@H_301_1@例如:

~]# grep -e "r..t" -e"bash" /etc/passwd@H_301_1@:使用多模式;

~]# grep -f /root/test/mypat /etc/passwd@H_301_1@:使用匹配保存在文件里的模式;

~]# grep -A 1 "^[op]" /etc/passwd@H_301_1@:显示匹配到的行后面的一行;

~]# grep -B 2 "^[op]" /etc/passwd@H_301_1@:显示匹配到的行前面的两行;

~]# grep -C 1 "^[op]" /etc/passwd@H_301_1@:显示匹配到的行前后各一行;

@H_301_1@模式用引号引起来,有变量时用单引号;

@H_301_1@三、基本正则表达式元字符

1.@H_301_1@字符匹配

.@H_301_1@:匹配任意单个字符;

[]@H_301_1@:匹配范围内的任意单个字符;(@H_301_1@同glob@H_301_1@机制)

[^]@H_301_1@:匹配范围外的单个字符;

[:digit:]@H_301_1@:任意单个数字;

[:lower:]@H_301_1@:任意单个小写字母:

[:upper:]@H_301_1@:任意单个大写字符;

[:alpha:]@H_301_1@:任意单个字母;

[:alnum:]@H_301_1@:任意单个字母和数字

[:space:]@H_301_1@:任意单个空白字符;

[:blank:]@H_301_1@:任意单个空格和tab@H_301_1@;

[:punct:]@H_301_1@:任意单个标点符号

[:cntrl:]@H_301_1@:任意单个控制符;

[:graph:]@H_301_1@:任意单个能显示的符号;

[:print:]@H_301_1@:任意单个可打印符号;

[:xdigit:]@H_301_1@:任意单个十六进制字符;

man 7 glob@H_301_1@查看字符集范围;

@H_301_1@例如:

~]# ifconfig | grep "r.."@H_301_1@:r@H_301_1@后跟两个字符的行;

~]# ifconfig | grep -i"i[a-z][a-z]"@H_301_1@:不区分大小写,i@H_301_1@后跟两个字母的行;

~]# ifconfig | grep "i[[:alpha:]][[:space:]]"@H_301_1@:i@H_301_1@后跟一个字母再跟一个空格的行;

2.@H_301_1@次数匹配

@H_301_1@用在要指定其出现的次数的字符后面,用于限制其前面的字符要出现的次数,默认工作在贪婪模式;

*@H_301_1@:匹配前面的字符出现的任意次(0,1@H_301_1@或多次);

grep "x*y"@H_301_1@:只要有y@H_301_1@就匹配;

xxxyabc

yab

abcxy

abcy

.*@H_301_1@:匹配任意长度的任意字符,相当于glob@H_301_1@中的*@H_301_1@;

grep "x.*y"@H_301_1@:在x@H_301_1@和y@H_301_1@之间可出现任意长度任意字符即匹配;

xxxyabc

abcxy

\+@H_301_1@:匹配前面的字符至少1@H_301_1@次(1@H_301_1@次或多次);\@H_301_1@为转义符;

grep "x\+y"@H_301_1@:y@H_301_1@之前必须出现一个x@H_301_1@;

xxxyabc

abcxy

\?@H_301_1@:匹配前面的字符0@H_301_1@次或1@H_301_1@次,即前面的字符可有可无;

grep "x\?y"@H_301_1@:只要有y@H_301_1@就匹配;

xxxyabc

yab

abcxy

abcy

\{m\}@H_301_1@:匹配其前面的字符出现m@H_301_1@次,m@H_301_1@为非负整数;

grep "x\{2\}y"@H_301_1@:y@H_301_1@前出现2@H_301_1@次x@H_301_1@就匹配;

xxxyabc

\{m,n\}@H_301_1@:匹配其前面的字符出现m@H_301_1@次,m@H_301_1@为非负整数;闭区间[m,n]

\{0,n\}@H_301_1@:至多n@H_301_1@次;

\{m,\}@H_301_1@:至少m@H_301_1@次;

@H_301_1@例如:

~]# ifconfig | grep"i[[:alpha:]]\{3\}"@H_301_1@:匹配i@H_301_1@后跟3@H_301_1@个字母的行;

~]# ifconfig | grep"i[[:alpha:]]\{3,\}"@H_301_1@:匹配i@H_301_1@后跟至少3@H_301_1@个字母的行;

3.@H_301_1@位置锚定

@H_301_1@限制使用模式搜索文本,限制模式所匹配到的文本只能出现于目标文本的哪个位置;

^@H_301_1@:行首锚定;用于模式的最左侧,^PATTERN@H_301_1@;

$@H_301_1@:行尾锚定;用于模式的最右侧,PATTERN$@H_301_1@;

^PATTERN$@H_301_1@:要让PATTERN@H_301_1@完全匹配一整行;

^$@H_301_1@:匹配空行;

^[[:space:]].*$@H_301_1@:匹配空白行;

@H_301_1@例如:

~]# grep "^r..t" /etc/passwd@H_301_1@:匹配r@H_301_1@开头后跟两个字符再跟t@H_301_1@的行;

~]# grep "l.\{3\}n" /etc/passwd@H_301_1@:匹配l@H_301_1@后跟3@H_301_1@个字符再跟n@H_301_1@的行;

~]# grep "l.\{3\}n$" /etc/passwd@H_301_1@:匹配l@H_301_1@后跟3@H_301_1@个字符再跟n@H_301_1@结尾的行;

~]# grep "^l.\{3\}n$" /etc/passwd@H_301_1@:匹配只能是l@H_301_1@开头后跟3@H_301_1@个字符再跟n@H_301_1@结尾的行;

~]# grep "[[:space:]]\+" /etc/passwd@H_301_1@:匹配至少连续出现一个空格的行;

@H_301_1@单词:非特殊字符组成的连续字符(字符串)都称为单词;

\<@H_301_1@或\b@H_301_1@:词首锚定,用于单词模式的左侧,格式为\<PATTERN,/bPATTERN@H_301_1@;

\>@H_301_1@或\b@H_301_1@:词尾锚定,用于的承诺模式的右侧,格式为PATTERN\>,PATTERN\b@H_301_1@;

@H_301_1@例如:

~]# grep "\<r..t" /etc/passwd@H_301_1@:匹配单词词首:r@H_301_1@后跟两个字符再跟t@H_301_1@的的行;

~]# grep "\<r..t\>"/etc/passwd@H_301_1@:匹配单词:r@H_301_1@后跟两个字符再跟t@H_301_1@的行;

~]# ifconfig | grep"\<[0-9]\{3\}\>"@H_301_1@:匹配单词:三个数字;

4.@H_301_1@分组与引用

\(PATTERN\)@H_301_1@:将此PATTERN@H_301_1@匹配到的字符当作一个不可分割的整体进行处理;

@H_301_1@注意:分组括号中的模式匹配到的字符会被正则表达式引擎自动记录于内部变量中,这些变量是\1,\2,\3,...

@H_301_1@例如:pat1\(pat2\)pat3\(pat4\(pat5)pat6\)

\n@H_301_1@:模式中的第n@H_301_1@个左括号以及与之匹配的右括号之间的模式所匹配到的字符串;(不是模式,而是模式匹配的结果)

\1@H_301_1@:表示第一组括号总的PATTERN@H_301_1@匹配到的的字符串;上例:pat2

\2@H_301_1@:表示第二组括号总的PATTERN@H_301_1@匹配到的的字符串;上例:pat4\(pat5)pat6

\3@H_301_1@:表示第三组括号总的PATTERN@H_301_1@匹配到的的字符串;上例:pat5

...

@H_301_1@示例:

he love his lover

he like his lover

he love his liker

he like his liker

.*l..e.*l..er

\(l..e\).*\1r

~]# grep -o 'l..e.*l..er' fenzu_pattern.txt@H_301_1@:不能完成精确匹配;

~]# grep -o '\(l..e\).*\1r'fenzu_pattern.txt@H_301_1@:分组可完成精确匹配;

@H_301_1@后向引用:引用前面的括号中的模式所匹配到的字符串;

@H_301_1@四、egrep@H_301_1@命令

@H_301_1@支持使用扩展的正则表达式的grep@H_301_1@命令,相当于grep -E@H_301_1@;

1.@H_301_1@语法格式

egrep [OPTIONS] PATTERN [FILE...]

2.@H_301_1@选项

@H_301_1@选项同grep@H_301_1@;

@H_301_1@五、扩展正则表达式的元字符:无需转义符

1.@H_301_1@字符匹配

.@H_301_1@:匹配任意单个字符;

[]@H_301_1@:匹配范围内的任意单个字符;

[^]@H_301_1@:匹配范围外的单个字符;

[:digit:]@H_301_1@:任意单个数字;

[:lower:]@H_301_1@:任意单个小写字母:

[:upper:]@H_301_1@:任意单个大写字符;

[:alpha:]@H_301_1@:任意单个字母;

[:alnum:]@H_301_1@:任意单个字母和数字

[:space:]@H_301_1@:任意单个空格;

[:blank:]@H_301_1@:任意单个空格和tab

[:punct:]@H_301_1@:任意单个标点符号

2.@H_301_1@次数匹配

*@H_301_1@:匹配前面的字符(可有可无)出现的任意次(0,1@H_301_1@或多次);

?@H_301_1@:匹配前面的字符0@H_301_1@次或1@H_301_1@次,即前面的字符可有可无;

+@H_301_1@:匹配前面的字符至少1@H_301_1@次(1@H_301_1@次或多次);

{m}@H_301_1@:匹配其前面的字符出现m@H_301_1@次,m@H_301_1@为非负整数;

{m,n}@H_301_1@:匹配其前面的字符出现m@H_301_1@次,m@H_301_1@为非负整数;[m,n]

{0,n}@H_301_1@:至多n@H_301_1@次;

{m,}@H_301_1@:至少m@H_301_1@次;

3.@H_301_1@位置锚定

^@H_301_1@:行首锚定;用于模式的最左侧,^PATTERN@H_301_1@;

$@H_301_1@:行尾锚定;用于模式的最右侧,PATTERN$@H_301_1@;

^PATTERN$@H_301_1@:要让PATTERN@H_301_1@完全匹配一整行;

^$@H_301_1@:匹配空行

\<,\b@H_301_1@:词首锚定,用于单词模式的左侧,格式为\<PATTERN,/bPATTERN@H_301_1@;

\>,\b@H_301_1@:词尾锚定,用于的承诺模式的右侧,格式为PATTERN\>,PATTERN\b@H_301_1@;

4.@H_301_1@分组及引用

(pattern)@H_301_1@:分组,括号中的模式匹配到的字符会被存储于正则表达式引擎内部的变量中;

@H_301_1@后向引用:\1,...

5.@H_301_1@或

a|b@H_301_1@:a@H_301_1@或者b

C|cat@H_301_1@:表示C@H_301_1@或cat@H_301_1@;

(C|c)at@H_301_1@:表示Cat@H_301_1@或cat@H_301_1@;

猜你在找的正则表达式相关文章