GREP正则表达式 扩展正则表达式 重定向
grep -i 忽略大小写
grep --color 把匹配到的项改变颜色显示
grep -v 反向显示
没有被匹配的行
grep -o 只显示被匹配到的字符串
alias grep='grep --color' 取一个别命 表示以后用grep 都会带 --color
grep -E 扩展正则表达式 和egrep 同一个意思
grep -A 被匹配到以后后面的行业会显示
grep -B 被匹配到以后前面的行业会显示
grep -C 匹配到前后两行都会显示
基本正则表达式:
字符匹配:
* 任意长度任意字符
?任意单个字符
[] 取范围内的
[^] 取范围外的
匹配次数:
. 任意一个单个字符
.* 任意长度任意次
\? 匹配前面的字符1次或0次
\{m,n\} 匹配前面的字符至少m次 最多n次
\{1,\} 最少一次 最多不限
\{0,3\} 最少0次最多3次
比如: grep 'a\{1,3\}b' test.txt
搜索a和b 之间出现最少1次 最多3次的字符
[] 匹配指定范围内的任意单个字符
[^] 匹配指定范围外的任意单个字符
匹配字符集:在结合grep 使用的时候再加[] 如 grep '[[:digit:]]' /etc/password
也可以多个结合使用 如 grep '[[:space:]] [[:digit:]]' /etc/password
[:digit:] 数字
[:lower:] 小写字母
[:upper:] 大写字母
[:punct:] 标点符号
[:space:] 空白字符
[:alpha:] 所有字母
[:alnum:] 所有数字或字母
位置锚定:
^ 锚定行守,次字符后面的任意内容必须出现到行首 如 grep '^r..t' /etc/passwd
$ 锚定行尾,次字符前面的任意内容必须出现到行尾 如 grep 'y$' /etc/passwd
^$ 空白行
\< 或 \b 其后面的任意字符必须作为单词首部出现 如 grep "\<root" test.txt
\>或\b
其前面的任意字符必须作为单词尾部出现 如 grep "root\>" test.txt
\< \> 或\b \b 精确匹配
如 grep '\<root\>' /etc/passwd
分组:
\(\) 如 \(ab\) 表示出现的必须是ab 它已经是一个整体, \(ab\)* 表示ab 可以出现1次 0次 任意次
如 grep '\([0-9]\).*\1$' /etc/inittab
查找行中出现任意数字 结尾又以相同数字结尾 ,\1 就是引用前面[0-9] 组
################# 举例说明###############
grep -i '^[sS]' /proc/meminfo
2、显示/etc/passwd中以nologin结尾的行;
grep 'nologin$' /etc/passwd
3、显示/etc/inittab中以#开头,且后面跟一个或多个空白字符,而后又跟了任意非空白字符的行;
grep '^#[[:space:]]\{1,\} [^[:space:]]' /etc/inittab
4、显示/etc/inittab中包含了:一个数字:(即两个冒号中间一个数字)的行;
grep ':[0-9]:' /etc/inittab
grep '^[[:space:]]\{1,\}' /boot/grub/grub.conf
grep --color '^\([0-9]\).*\1$' /etc/inittab
7、找出某文件中的,1位数,或2位数;
grep '\([0-9]\)\{1,2\}' /xxx/xxx
grep --color '\bstudent:' /etc/passwd
9,分析/etc/inittab文件中如下文本中前两行的特征(每一行中出现在数字必须相同),请写出可以精确找到类似两行的模式:
l1:1:wait:/etc/rc.d/rc 1
l3:3:wait:/etc/rc.d/rc 3
grep --color 'l\([0-9]\):\1.*\1' /etc/inittab