---恢复内容开始---
正则就是用一些具有特殊含义的符号组合到一起(称为正则表达式)来描述字符或者字符串的方法。或者说:正则就是用来描述一类事物的规则。
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 ‘^ *$‘
---恢复内容结束---
原文:http://www.cnblogs.com/zhangsunan/p/6934892.html