Linux 正则表达式

2018-12-06 17:50 更新

Linux 正则表达式

这部分内容可以说是学习shell脚本之前必学的内容如果你这部分内容学的越好,那么你的shell脚本编写能力就会越强所以不要嫌这部分内容啰嗦,也不要怕麻烦,要用心学习一定要多加练习,练习多了就能熟练掌握了

在计算机科学中,正则表达式是这样解释的:它是指一个用来描述或者匹配一系列符合某个句法规则的字符串的单个字符串在很多文本编辑器或其他工具里,正则表达式通常被用来检索和/或替换那些符合某个模式的文本内容许多程序设计语言都支持利用正则表达式进行字符串操作对于系统管理员来讲,正则表达式贯穿在我们的日常运维工作中,无论是查找某个文档,抑或查询某个日志文件分析其内容,都会用到正则表达式

其实正则表达式,只是一种思想,一种表示方法只要我们使用的工具支持表示这种思想那么这个工具就可以处理正则表达式的字符串常用的工具有grep, sed, awk 等,下面笔者就介绍一下这三种工具的使用方法

grep / egrep

笔者在前面的内容中多次提到并用到grep命令,可见它的重要性所以好好学习一下这个重要的命令吧你要知道的是grep连同下面讲的sed, awk都是针对文本的行才操作的

语法: grep [-cinvABC] ‘word’ filename

-c :打印符合要求的行数

-i :忽略大小写

-n :在输出符合要求的行的同时连同行号一起输出

-v :打印不符合要求的行

-A :后跟一个数字(有无空格都可以),例如 –A2则表示打印符合要求的行以及下面两行

-B :后跟一个数字,例如 –B2 则表示打印符合要求的行以及上面两行

-C :后跟一个数字,例如 –C2 则表示打印符合要求的行以及上下各两行

13_1.png.jpg

以下,笔者举几个小例子帮助你好好掌握这个grep工具的用法

a. 过滤出带有某个关键词的行并输出行号

13_7.png.jpg

b. 过滤不带有某个关键词的行,并输出行号

13_8.png.jpg

c. 过滤出所有包含数字的行

13_9.png.jpg

在前面也提到过这个”[ ]”的应用,如果是数字的话就用[0-9]这样的形式,当然有时候也可以用这样的形式[15]即只含有1或者5,注意,它不会认为是15。如果要过滤出数字以及大小写字母则要这样写[0-9a-zA-Z]。另外[ ]还有一种形式,就是[^字符] 表示除[ ]内的字符之外的字符

13_10.png.jpg

这就表示筛选包含oo字符串,但是不包含r字符

d. 过滤出文档中以某个字符开头或者以某个字符结尾的行

13_11.png.jpg

在正则表达式中,”^”表示行的开始,”$”表示行的结尾,那么空行则表示”^$”,如果你只想筛选出非空行,则可以使用 “grep -v ‘^$’ filename”得到你想要的结果现在想一下,如何打印出不以英文字母开头的行呢?

13_21.png.jpg

e. 过滤任意一个字符与重复字符

13_22.png.jpg

“.”表示任意一个字符,上例中,就是把符合ro之间有两个任意字符的行过滤出来

“*”表示零个或多个前面的字符

13_23.png.jpg

‘ooo 表示oo, ooo, oooo … 或者更多的’o’。现在你是否想到了’.’ 这个组合表示什么意义?

13_24.png.jpg

‘.*’表示零个或多个任意字符,空行也包含在内

f. 指定要过滤字符出现的次数

13_25.png.jpg

这里用到了{ },其内部为数字,表示前面的字符要重复的次数上例中表示包含有两个o ’oo’的行注意,{ }左右都需要加上脱意字符’\’。另外,使用{ }我们还可以表示一个范围的,具体格式是 ‘\’其中n1<n2,表示重复n1n2次前面的字符,n2还可以为空,则表示大于等于n1

上面部分讲的grep,另外笔者常常用到egrep这个工具,简单点讲,后者是前者的扩展版本,我们可以用egrep完成grep不能完成的工作,当然了grep能完成的egrep完全可以完成如果你嫌麻烦,egrep了解一下即可,因为grep的功能已经足够可以胜任你的日常工作了下面笔者介绍egrep不用于grep的几个用法为了试验方便,笔者把test.txt 编辑成如下内容:

rot:x:0:0:/rot:/bin/bash

operator:x:11:0:operator:/root:/sbin/nologin

operator:x:11:0:operator:/rooot:/sbin/nologin

roooot:x:0:0:/rooooot:/bin/bash

1111111111111111111111111111111

aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa

a. 筛选一个或一个以上前面的字符

13_26.png.jpg

grep 不同的是,egrep这里是使用’+’

b. 筛选零个或一个前面的字符

13_27.png.jpg

c. 筛选字符串1或者字符串2

13_28.png.jpg

中间有一个’|’表示或者的意思,笔者用这个用的很多,所以这个你最好记一下

d. egrep’( )’的应用

13_29.png.jpg

’( )’表示一个整体,例如(oo)+就表示1’oo’或者多个’oo’

13_44.png.jpg

sed 工具的使用

grep 工具的功能其实还不够强大,其实说白了,grep实现的只是查找功能,而它却不能实现把查找的内容替换掉以前用vim的时候,可以查找也可以替换,但是只局限于在文本内部来操作,而不能输出到屏幕上。sed工具以及下面要讲的awk工具就能实现把替换的文本输出到屏幕上的功能了,而且还有其他更丰富的功能。sedawk都是流式编辑器,是针对文档的行来操作的

a. 打印某行 sed -n ‘n’p filename 单引号内的n是一个数字,表示第几行

13_45.png.jpg

b. 打印多行打印整个文档用 -n ‘1,$’p

13_46.png.jpg

c. 打印包含某个字符串的行

13_47.png.jpg

上面grep中使用的特殊字符,如’^’, ‘$’, ‘.’, ‘*’等同样也能在sed中使用

13_48.png.jpg

13_49.png.jpg

d. -e 可以实现多个行为

13_50.png.jpg

e. 删除某行或者多行

13_51.png.jpg

‘d’ 这个字符就是删除的动作了,不仅可以删除指定的单行以及多行,而且还可以删除匹配某个字符的行,另外还可以删除从某一行一直到文档末行

13_52.png.jpg

f. 替换字符或字符串

13_53.png.jpg

以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号