linux正则表达式

一、linux正则表达式的概念。

1、什么是正则表达式?

简单地说,正则表达式就是为处理大量的字符串而定义的一套规则和方法,例如:假设“#”代表 oldboy,“%”代表oldgirl。echo “#%”==”oldboyoldgirl”通过定义的这些特殊符号的辅助,系统管理员就可以快速过滤,替换或输出需要的字符串。linux正则表达式一般以行尾单位处理的。

 

2、为什么要学会正则表达式?

在企业工作中,我们每天做的linux运维工作中,时刻都会面对大量带有字符串的文本配置、程序、命令输出及日志文件等,而我们经常会有迫切的需要,从大量的字符串内容中查找符合工作需要的特定的字符串。这就要靠正则表达式。因此,可以说正则表达式就是过滤这样字符串的需求而生的!

 

3、容易混淆的两个注意事项:

 

3.1、正则表达式应用非常广泛,存在于各种语言中,例如:php,python,java等。但是,我们linux系统运维工作中的正则表达式,最常应用正则表达式的命令就是grep(egrep),sed,awk,换句话说linux三剑客要想能工作的更高效,那一定离不开正则表达式的配合。

 

3.2、正则表达式和我们常用的通配符特殊字符是有本质区别的,这一点要注意。通配符例子:ls *.log 这里的*就是通配符(表示所有),不是正则表达式。

 

二、基础正则字符说明:

1、^word 匹配以word开头的内容。 vi/vim 编辑器里 ^代表一行的开头。

例子:

[root@oldboy test]# grep "^m" oldboy.log 

my blog is http://oldboy.blog.51cto.com

my qq num is 49000448.
my god ,i am not oldbey,but OLDBOY!

 

2、word$ 匹配以word结尾的内容。 vi/vim 编辑器里 $代表一行的结尾。

例子:

[root@oldboy test]# grep "m$" oldboy.log  

my blog is http://oldboy.blog.51cto.com

 

3、^$     表示空行。

例子:

[root@oldboy test]# grep -n "^$" oldboy.log 

3:
8:

4、.      代表且只能代表任意一个字符。

例子:

[root@oldboy test]# grep -n "." oldboy.log    

1:I am oldboy teacher!
2:I teach linux.
4:I like badminton ball ,billiard ball and chinese chess!
5:my blog is http://oldboy.blog.51cto.com
6:our site is 
http://www.etiantian.org
7:my qq num is 49000448.
9:not 4900000448.
10:my god ,i am not oldbey,but OLDBOY!

 

5、\      专义字符,例\.就只代表点本身,让特殊身份意义的字符脱掉马甲,还原原型。

例子:

[root@oldboy test]# grep -n "\.$" oldboy.log 

2:I teach linux.
7:my qq num is 49000448.
9:not 4900000448.

 

6、*    重复0个或多个前面的一个字符,例o*匹配没有o,有1个o或多个oooo 。

例子:

[root@oldboy test]# egrep "go*d" oldboy.log 

my god ,i am not oldbey,but OLDBOY!
gd
good

 

7、.*    匹配所有的字符。延伸^.* 以任意多个字符开头。.*$以任意多个字符结尾。

例子:

[root@oldboy test]# grep -n ".*" oldboy.log 

1:I am oldboy teacher!
2:I teach linux.
3:
4:I like badminton ball ,billiard ball and chinese chess!
5:my blog is http://oldboy.blog.51cto.com
6:our site is 
http://www.etiantian.org
7:my qq num is 49000448.
8:
9:not 4900000448.

 

8、[abc]   匹配字符集合内的任意一个字符[a-z A-Z],[0-9]。

例子:

[ oldboy]# grep "[0-9]" oldboy.log     

my blog is 

my qq num is 49000448.

not 4900000448.

 

9、[^abc]  匹配不包含^后的任意一个字符串的内容。中括号里的^为取反,注意和中括号外面以…开头区别。

例子:

[root@oldboy oldboy]# grep "[^abc]" oldboy.log

I am oldboy teacher!

I teach linux.

I like badminton ball ,billiard ball and chinese chess!

my blog is http://oldboy.blog.51cto.com

our site is http://www.etiantian.org

my qq num is 49000448.

not 4900000448.

my god ,i am not oldboy,but OLDBOY!

good

goood

gd

 

10、a\{n,m\}  重复n到m次,前一个重复的字符。如果用egrep/sed-r可以去掉斜线。

例子:

[ oldboy]# grep "0\{3,4\}" oldboy.log 

my qq num is 49000448.

not 4900000448.

 

11、a\{n,\}  重复至少n次,前一个重复的字符。如果用egrep/sed -r可以去掉斜线。

例子:

[ oldboy]# grep "0\{3,\}" oldboy.log 

my qq num is 49000448.

not 4900000448.

 

12、a\{n\}  重复n次,前一个重复的字符。如果用egrep/sed -r可以去掉斜线。

例子:

[ oldboy]# grep "0\{3\}" oldboy.log      

my qq num is 49000448.

not 4900000448.

 

13、a\{,m\}  ?????CentOS5不能用,CentOS6可以了

例子:

[ oldboy]# grep "0\{3\}" oldboy.log      

my qq num is 49000448.

not 4900000448.

 

 

提示:点(.)的特殊含义小结;

      1、当前目录

      2、使得文件生效相当于source

      3、隐藏文件

      4、任意一个字符(grep正则)

 

注意:egrep(grep -E)或sed -r过滤一般特殊字符可以不转义(不用\)。

 

14、grep 参数小结:

 -a:在二进制文件中,以文本文件的方式搜索数据

 -c : 计算找到‘搜索字符串’的次数

 -o:仅显示出匹配regexp的内容(用于统计出现在文件的次数)

 -i *****:忽略大小写的不同,所以大小写视为相同*****

 -n*****:匹配的内容再其行首显示行号*****

 -v*****:反向选择,及显示没有‘搜索字符串’内容的那一行*****

 -E*****:扩展的grep,即egrep*****

 --color=auto:以特定颜色高亮显示匹配关键字***

#提示: -i  -v 为常用参数 。

 -A :After的意思,显示匹配字符串及其后n行是数据

 -B :before 的意思,显示匹配字符串及其前的n行的数据

 -C :context 的意思,显示匹配字符串及前后各num行

 

三、扩展的正则表达式(ERE):

扩展的正则表达式使用的命令为: grep -E以及egrep 【了解即可】

 

1、+ 表示重复 “一个或一个以上”前面的字符(*是0或多个)

例子:

[root@oldboy test]# egrep "go+d" oldboy.log

my god ,i am not oldbey,but OLDBOY!
good

 

2、?表示重复 “0个或一个”前面的字符

例子:

[root@oldboy oldboy]# egrep "go?d" oldboy.log

my god ,i am not oldboy,but OLDBOY!

gd

 

3、| 表示同时过滤多个字符串

例子:

[root@oldboy oldboy]# egrep "good|not" oldboy.log 

not 4900000448.

my god ,i am not oldboy,but OLDBOY!

good

 

4、() 分组过滤,后向引用

例子:

[root@oldboy oldboy]# egrep "(good)" oldboy.log   

good