正则表达式

---恢复内容开始---

正则就是用一些具有特殊含义的符号组合到一起(称为正则表达式)来描述字符或者字符串的方法。或者说:正则就是用来描述一类事物的规则。

grep:文本搜索

-n  :显示行号
-o  :只显示匹配的内容
-q  :静默模式,没有任何输出,得用$?来判断执行成功没有,即有没有过滤到想要的内容

-l  :如果匹配成功,则只将文件名打印出来,失败则不打印,通常-rl一起用,grep -rl 'root' /etc 
-A  :如果匹配成功,则将匹配行及其后n行一起打印出来
-B  :如果匹配成功,则将匹配行及其前n行一起打印出来
-C  :如果匹配成功,则将匹配行及其前后n行一起打印出来
--color
-c  :如果匹配成功,则将匹配到的行数打印出来
-E  :等于egrep,扩展
-i  :忽略大小写

-v  :取反,不匹配
-w:匹配单词

介绍:

^:以什么什么开头

$:以是什么什么结尾

*:左边字符零个或多个

.*:所有字符

.:代表一个字符

{n}:左边字符有n个

{n}$:左边字符n个结尾

[]:字符组内的任一字符

[a-z]:a到z中任一单字符

[a-zA-Z]:a到z和A到Z中任一单字符

[a-Z]:就是[a-zA-Z]

扩展正则

grep 加 -E 或 egrep 或转义

?:左边字符为零个或1个
+: 前导字符一个或多个
abc|def abc或def
a(bc|de)f abcf 或 adef
x{m} x出现m次
x{m,} x出现m次至多次(至少m次)
x{m,n} x出现m次至n次

作业

grep作业(正则表达式及字符处理)

目标文件/etc/passwd,使用grep命令或egrep
1.显示出所有含有root的行:

 # grep 'root' /etc/passwd                           

2.输出任何包含bash的所有行,还要输出紧接着这行的上下各两行的内容:

 # grep -C 2 'bash' /etc/passwd                                                      

3.  显示出有多少行含有nologin。

 # grep -c 'nologin' /etc/passwd                   

4.显示出那些行含有root,并将行号一块输出。

 # grep -n 'root' /etc/passwd                      

5.新建用户
abominable
abominate
anomie
atomize
编写正则表达式,将他们匹配出来

 # egrep 'a.omi(nabl|nat|z|)e' /etc/passwd          

6.建四个用户
Alex213sb
Wpq2222b
yH438PIG
egon666
egon

过滤出用户名组成是字母+数字+字母的行

 # egrep '^[a-Z]+[0-9]+[a-Z]+' /etc/passwd       

7.显示出/etc目录下所有包含root的文件名

 # find /etc | egrep 'root'                    

 9. 过滤掉/etc/ssh/sshd_config内所有注释和所有空行

 # grep -v '^#' /etc/ssh/sshd_config |grep -v '^ *$' 

---恢复内容结束---

原文地址:https://www.cnblogs.com/zhangsunan/p/6934892.html