GREP 正则表达式 扩展正则表达式 重定向
grep -i忽略大小写
grep --color把匹配到的项改变颜色显示
grep -o只显示被匹配到的字符串
alias grep='grep --color'取一个别命 表示以后用grep 都会带 --color
grep -E 扩展正则表达式 和egrep 同一个意思
grep -B 被匹配到以后前面的行业会显示
grep -C 匹配到前后两行都会显示
基本正则表达式:
字符匹配:
* 任意长度任意字符
?任意单个字符
[] 取范围内的
[^] 取范围外的
匹配次数:
. 任意一个单个字符
.* 任意长度任意次
\? 匹配前面的字符1次或0次
\{m,n\} 匹配前面的字符至少m次 最多n次
\{1,\} 最少一次 最多不限
\{0,3\} 最少0次最多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
扩展正则表达式:
字符匹配的:
. 任意字符
[] 匹配范围内
[^] 匹配范围外的
次数匹配的
* 任意字符任意次
?出现一次或0次
+ 匹配前面字符至少1次
锚定:
^行首锚定
$行尾锚定
\<锚定词首
\>锚定词尾
分组:
() 分组
\1,\2,\3 引用
| 或者
如 C|cat表示匹配C或者cat,(c|C)at 匹配大写或小写的C
" < "输入重定向
强制覆盖 使用 " >| " 即可