15.基本正则表达式

1.正则表达式和通配符区别


通配符
功能:是匹配文件名的字符串

*:表示任意字符,例如:*.log  已.log结尾的文件
?:表示单个字符
[]:表示括号里的任意字符
[^]:表示除了括号里的字符
[0-9]: 匹配数字范围
[a-z]:字母  显示aA bB...z 没有大写Z
[A-Z]:字母  显示A bB ……zZ 没有小写a
[:digit:]:任意数字,相当于0-9
[:lower:]:任意小写字母
[:upper:]: 任意大写字母
[:alpha:]: 任意大小写字母
[:alnum:]:任意数字或字母

正则表达式
功能:功能比通配符功能要强,匹配的对象是文本内容的字符串,也可能是由其他命令输出的内容。
正则表达式分为:基本正则表达式和扩展正则表达式
查看帮助:man 7 regex

2.字符匹配


. : 表示任意单个字符。
* : 表示前面的字符连续出现任意次,包括0次。
.* :表示任意长度的任意字符,与通配符中的*的意思相同。
\  :表示转义符,当与正则表达式中的符号结合时表示符号本身。
[  ]:表示匹配指定范围内的任意单个字符。
[^ ]:表示匹配指定范围外的任意单个字符。

[[:alpha:]]  表示任意一位大小写字母。
[[:lower:]]  表示任意一位小写字母。
[[:upper:]]  表示任意一位大写字母。
[[:digit:]]  表示0到9之间的任意单个数字。
[[:alnum:]]  表示任意一位数字或字母。
[[:space:]]  表示任意空白字符,包括"空格"、"tab键"等。
[0-9]与[[:digit:]]等效。
[a-z]与[[:lower:]]等效。
[A-Z]与[[:upper:]]等效。
[a-zA-Z]与[[:alpha:]]等效。
[a-zA-Z0-9]与[[:alnum:]]等效。

3.次数匹配


\?  :表示匹配其前面的字符0或1次
\+  :表示匹配其前面的字符至少1次,或者连续多次,连续次数上不封顶。
\{n\} :表示前面的字符连续出现n次,将会被匹配到。
\{x,y\} :表示之前的字符至少连续出现x次,最多连续出现y次
\{,n\} :表示之前的字符连续出现至多n次,最少0次,都会陪匹配到。
\{n,\} :表示之前的字符连续出现至少n次,才会被匹配到。

4.位置匹配


^:表示锚定行首,此字符后面的任意内容必须出现在行首,才能匹配。
$:表示锚定行尾,此字符前面的任意内容必须出现在行尾,才能匹配。
^$:表示匹配空行,这里所描述的空行表示"回车",而"空格"或"tab"等都不能算作此处所描述的空行。
^abc$:表示abc独占一行时,会被匹配到。
\<或者\b :匹配单词边界,表示锚定词首,其后面的字符必须作为单词首部出现。
\>或者\b :匹配单词边界,表示锚定词尾,其前面的字符必须作为单词尾部出现。
\B:匹配非单词边界,与\b正好相反。

5.分组和后向引用


分组:a{2},这种是匹配单个字符,若干要匹配多个字符,就要分组,比如:(hello){2}

分组括号中的模式匹配到的内容会被正则表达式引擎记录于内部的变量中,这些变量的命名方式为: \1, \2, \3, …
\1 表示从左侧起第一个左括号以及与之匹配右括号之间的模式所匹配到的字符
示例: (string1+(string2)*) 红色左括号代表第一个,黄色括号代表第二个
\1 :string1+(string2)*
\2 :string2
后向引用:引用前面的分组括号中的模式所匹配字符结果,而非模式本身
或者:|
示例:a|b: a或b 、C|cat: C或cat、 (C|c)at:Cat或cat

分组嵌套示例解释:
echo “abefefabefef22”| grep “(ab(ef){2}){2}”
第一步把匹配模式里的\去掉,得:(ab(ef){2}){2}
(ef){2}表示:”ef”这个整体出现2次,即efef,整体也就是:(abefef){2}
同理:(abefef){2}表示:”abefef”这个整体出现2次,即abefefabefef
以上就是一种嵌套分组,大的分组里有个小分组

小结:
( ) 表示分组,我们可以将其中的内容当做一个整体,分组可以嵌套。
(ab) 表示将ab当做一个整体去处理。
\1 表示引用整个表达式中左边第1个分组中的正则匹配到的结果。
\2 表示引用整个表达式中左边第2个分组中的正则匹配到的结果。

6.练习


练习:

1、显示/proc/meminfo文件中以大小s开头的行(要求:使用两种方法)

    #cat /proc/meminfo | grep "^[Ss]"
    #cat /proc/meminfo | grep -i "^S"

2、显示/etc/passwd文件中不以/bin/bash结尾的行

#cat /etc/passwd | grep -v "/bin/bash$"

3、显示用户rpc默认的shell程序

#cat /etc/passwd | grep "\<rpc\>" |cut -d: -f7

4、找出/etc/passwd中的两位或三位数

#cat /etc/passwd | grep -w "\<[0-9]\{2,3\}\>"

5、显示CentOS7的/etc/grub2.cfg文件中,至少以一个空白字符开头的且后面有非空白字符的行

#cat /etc/grub2.cfg | grep "^[[:space:]]\+[^[:space:]]"

6、找出“netstat -tan”命令结果中以LISTEN后跟任意多个空白字符结尾的行

#netstat -tan|grep "\<LISTEN\>[[:space:]]\+*"

7、显示CentOS7上所有系统用户的用户名和UID

#cat /etc/passwd | cut -d: -f1,3

8、添加用户bash、testbash、basher、sh、nologin(其shell为/sbin/nologin),找出/etc/passwd用户名和shell同名的行

#cat /etc/passwd |cut -d: -f1,7|tr "/" ":"|cut -d: -f1,4 | grep -o "\(\<.*\>\):\1"
#grep -o "\([[:alpha:]]\+\>\).*\<\1$" /etc/passwd

9、利用df和grep,取出磁盘各分区利用率,并从大到小排序

#df -h | grep "^/dev/sd*"|tr -s " " "%"|cut -d% -f5|sort -rn
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值