首页 > 其他 > 详细

grep正则表达式

时间:2015-08-31 23:54:42      阅读:374      评论:0      收藏:0      [点我收藏+]

1.回归本次课程主要知识点

chmod, chown, umask, grep, egrep

权限管理:

权限管理: chmod

所属关系管理: chown, chgrp

文件遮罩码:umask

grep: 文本过滤工具;egrep:grep的扩展版

 

2.grep基本语法

grep [OPTIONS] PATTERN [FILE...]

选项:

--color=auto:对匹配到的串做高亮显示;

-v:显示模式匹配不到行;

-i: 忽略字符大小写;

-o: 仅显示能够被模式匹配到的串本行;

-q: 静默模式;

-E:使用扩展的正则表达式;

 

基本正则表达式的元字符:

字符匹配:

.: 匹配任意单个字符;

[]:匹配指定范围内的任意单个字符;

[^]:匹配指定范围内的任意单个字符;

 

[:lower:], [:upper:], ...

 

次数匹配:用于要指定其次数的字符的后面;

*: 任意次;

abxy

xay

xxxxxxxy

 

grep "x*y"

 

\?01次;

grep "x\?y" 

 

\+1或多次

\{m\}:精确限制为m次;

\{m,n\}: 至少m次,至多n次,[m,n]

\{0,n\}:至多n次;

\{m,\}:至少m次;

 

.*: 匹配任意长度的任意字符;

 

位置锚定:

^: 行首锚定;用于模式的最左侧;

$: 行尾锚定;用于模式的最右侧;

\<, \b: 词首锚定;用于表示单词的模式的左侧;

\>, \b:词尾锚定;用于表示单词的模式的右侧;

^$: 空白行;

 

分组:\(\)

 

分组的小括号中的模式匹配到的内容,会在执行过程中被正则表达式引擎记录下来,并保存内置的变量中;这些变量分别是\1, \2, ...

\1: 从左侧起,第一个左括号,以及与之配对的右括号中间的模式所匹配到的内容;

\2


 

3、显示/etc/passwd文件中以bash结尾的行

#grep “bash$”/etc/passwd


 

4、显示/etc/passwd文件中的两位数或三位数

#grep "\<[1-9][0-9]\{1,2\}\>" /etc/passwd

 

5、显示`netstat -tan`命令结果中以‘LISTEN’后跟0个、1个或者多个空白字符结尾的行

# netstat -tan |grep -n "\<LISTEN[[:space:]]*$"

 

6、添加用户bashtestbashbasher以及nologin用户(nologin用户的shell/sbin/nologin);而后找出/etc/passwd文件中用户名与其shell名相同的行

#useradd bash
#useradd testbash
#useradd basher
#useradd nologin -s /sbin/nologin
#grep "^\(\<[[:alnum:]]\+\>\).*\1$" /etc/passwd


 

 

8、找出/etc/rc.d/init.d/functions文件中某单词(单词中间可以存在下划线)后面跟着一组小括号的行

 grep "\<[[:alnum:]_]\+\>()" /etc/rc.d/init.d/functions


 

 

9、使用echo输出一个路径,而后egrep找出其路径基名;进一步的使用egrep取出其目录名

#echo /home/mysql/xo/test.sh |grep ‘.*/’

取出目录名想不会写

 

10、找出ifconfig命令执行结果中1-255之间的数字

 ifconfig |grep -E "\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-5][0-5])\>"

 

 这题暂时水平只能写这样了


grep正则表达式

原文:http://betterman.blog.51cto.com/9659490/1690339

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!