正则表达式与扩展正则表达式

基本正则表达式

字符匹配:
.:匹配任意单个字符
[]:匹配指定范围内的任意单个字符
[^]:匹配指定范围外的任意单个字符
[-]:匹配[]中指定范围内的任意一个字符,要写成递增
POSIX字符类:
[:digit:]:匹配任意一个数字字符
[:lower:]:匹配小写字母
[:upper:]:匹配大写字母
[:alpha:]:匹配任意一个字母字符(包括大小写字母)
[:alnum:]:匹配任意一个字母或数字字符
[:space:]:匹配一个包括换行符、回车等在内的所有空白符
[:punct:]:匹配标点符号
\:转义符,将特殊字符进行转义,忽略其特殊意义
匹配次数:
*:匹配前面的字符任意次
.*:任意长度的任意字符
\?:匹配其前面的字符0或1次;即前面的可有可无
\+:匹配其前面的字符至少1次;
\{m\}:匹配前面的字符m次;
\{m,n\}:匹配前面的字符至少m次,至多n次;
\{0,n\}:匹配前面的字符至多n次;
\{m,\}:匹配前面的字符至少m次;
位置锚定:
^:行首锚定;用于模式的最左侧;
$:行尾锚定;用于模式的最右侧;
^PATTERN$: 用于模式匹配整行;
^$: 空行;
^[[:space:]]*$:空白行
单词锚定:
\< 或 \b:词首锚定;用于单词模式的左侧;
\> 或 \b:词尾锚定;用于单词模式的右侧;
\<PATTERN\>:匹配整个单词;
分组:
\(\):将一个或多个字符捆绑在一起,当作一个整体进行处理;\(xy\)*ab
Note: 分组括号中的模式匹配到的内容会被正则表达式引擎记录于内部的变量中,这些变量的命名方式为: \1, \2, \3, …
\1: 从左侧起,第一个左括号以及与之匹配右括号之间的模式所匹配到的字符;
\2:从左侧起,第二个左括号以及与之匹配右括号之间的模式所匹配到的字符;
\(ab\+\(xy\)*\):
\1: ab\+\(xy\)*
\2: xy
后向引用:引用前面的分组括号中的模式所匹配字符,(而非模式本身)

扩展正则表达式:

字符匹配
.:匹配任意单个字符
[]:匹配指定范围内的任意单个字符
[^]:匹配指定范围外的任意单个字符
[-]:匹配[]中指定范围内的任意一个字符,要写成递增
POSIX字符类:
[:digit:]:匹配任意一个数字字符
[:lower:]:匹配小写字母
[:upper:]:匹配大写字母
[:alpha:]:匹配任意一个字母字符(包括大小写字母)
[:alnum:]:匹配任意一个字母或数字字符
[:space:]:匹配一个包括换行符、回车等在内的所有空白符
[:punct:]:匹配标点符号
\:转义符,将特殊字符进行转义,忽略其特殊意义
匹配次数:
*:匹配前面的字符任意次
.*:任意长度的任意字符
?:匹配其前面的字符0或1次;即前面的可有可无
+:匹配其前面的字符至少1次;
{m}:匹配前面的字符m次;
{m,n}:匹配前面的字符至少m次,至多n次;
{0,n}:匹配前面的字符至多n次;
{m,}:匹配前面的字符至少m次;
位置锚定:
^:行首锚定;用于模式的最左侧;
$:行尾锚定;用于模式的最右侧;
^PATTERN$: 用于模式匹配整行;
^$: 空行;
^[[:space:]]*$:空白行
单词锚定:
\< 或 \b:词首锚定;用于单词模式的左侧;
\> 或 \b:词尾锚定;用于单词模式的右侧;
\<PATTERN\>:匹配整个单词;
分组:
():将一个或多个字符捆绑在一起,当作一个整体进行处理;
(xy)*abNote:分组括号中的模式匹配到的内容会被正则表达式引擎记录于内部的变量中,这些变量的命名方式为: \1, \2, \3, …
\1: 从左侧起,第一个左括号以及与之匹配右括号之间的模式所匹配到的字符;
\2:从左侧起,第:二个左括号以及与之匹配右括号之间的模式所匹配到的字符;
后向引用:引用前面的分组括号中的模式所匹配字符,(而非模式本身)
或者:
a|b
C|cat: C或cat

例题:
1、显示/proc/meminfo文件中以大小s开头的行;(要求:使用两种方式)
grep “^[sS]” /proc/meminfo
      grep -i “^s” /proc/meminfo
      grep -e ^s -e ^S /proc/meminfo
      grep “^S \| ^s” /proc/meminfo

2、显示/etc/passwd文件中不以/bin/bash结尾的行;
grep -v “/bin/bash$” /etc/passwd

3、显示/etc/passwd文件中ID号最大的用户的用户名;
sort -t: -k 3 /etc/passwd | cut -d: -f 1 | tail -n 1

4、如果用户root存在,显示其默认的shell程序;
  id root &> /dev/null && grep “^root\>” /etc/passwd | cut -d: -f7

5、找出/etc/passwd中的两位或三位数;
  grep “\<[0-9]\{2,3\}\>” /etc/passwd –color=auto
6、显示/etc/rc.d/rc.sysinit文件中,至少以一个空白字符开头的且后面存非空白字符的行;
grep “^[[:space:]]\+[^[:space:]]” /etc/rc.d/rc.sysinit
7、找出”netstat -tan”命令的结果中以’LISTEN’后跟0、1或多个空白字符结尾的行;
   netstat -tan | grep “LISTEN[[:space:]]*$”

8、添加用户bash、testbash、basher以及nologin(其shell为/sbin/nologin);而后找出/etc/passwd文件中用户名同shell名的行;
         grep “^\([[:alnum:]]\+\>\).*\1$” /etc/passwd
9、显示/etc/passwd文件中其默认shell为非/sbin/nologin的用户;
grep -v “/sbin/nologin$” /etc/passwd
10、显示/etc/passwd文件中其默认shell为/bin/bash的用户;
grep “/bin/bash$” /etc/passwd

11、找出/etc/passwd文件中的一位数或两位数:

grep –color=auto “\b[0-9]\{1,2\}\b” /etc/passwd

12、显示/boot/grub/grub.conf中以至少一个空白字符开头的行;
grep “^[:space:]\+[^[:space:]]” /boot/grub/grub.conf

13、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行;
grep “^#.*[:space:]\+[^[:space:]]” /boot/grub/grub.conf

14、使用echo命令输出一个绝对路径,使用grep取出其基名;
echo “/etc/passwd/” | grep -o “[[:alpha:]]\+” | tail -n
1扩展:取出其路径名
echo “/etc/passwd” | sed ‘s@[^/]\+/\?$@@’

 例题:

1、显示/proc/meminfo文件中以大小s开头的行;(要求:使用三种方式)
egrep “^[sS]” /proc/meminfo
       egrep -i “^s” /proc/meminfo
       egrep “^(s|S)” /proc/meminfo
2、显示/etc/passwd文件中不以/bin/bash结尾的行;
  egrep -v “/bin/bash$” /etc/passwd
3、显示/etc/passwd文件中ID号最大的用户的用户名;
sort -t: -k 3 /etc/passwd | cut -d: -f 1 | tail -n 1
4、如果用户root存在,显示其默认的shell程序;
id root &> /dev/null && egrep “^root\>” /etc/passwd | cut -d: -f7
5、找出/etc/passwd中的两位或三位数;
egrep “\<[0-9]{2,3}\>” /etc/passwd
6、显示/etc/rc.d/rc.sysinit文件中,至少以一个空白字符开头的且后面存非空白字符的行;
egrep “^[[:space:]]+[^[:space:]]” /etc/rc.d/rc.sysinit
7、找出”netstat -tan”命令的结果中以’LISTEN’后跟0、1或多个空白字符结尾的行;
netstat -tan | egrep “LISTEN[[:space:]]*$”
8、添加用户bash、testbash、basher以及nologin(其shell为/sbin/nologin);而后找出/etc/passwd文件中用户名同shell名的行;
egrep “^([[:alnum:]]+\>).*\1$” /etc/passwd
9、显示/etc/passwd文件中其默认shell为非/sbin/nologin的用户;
egrep -v “/bin/nologin” /etc/passwd
10、显示/etc/passwd文件中其默认shell为/bin/bash的用户;
egrep “/bin/bash” /etc/passwd
11、找出/etc/passwd文件中的一位数或两位数;
egrep “\b[0-9]{1,2}\b” /etc/passwd

12、显示/boot/grub/grub.conf中以至少一个空白字符开头的行;
egrep “[:space:]+[^[:space:]]” /boot/grub/grub.conf

13、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行;
egrep “^#+[:space:]+[^[:space:]]” /boot/grub/grub.conf

14、打出netstat -tan命令执行结果中以‘LISTEN’,后或跟空白字符结尾的行;
egrep “^#.*[:space:]+[^[:space:]]” /boot/grub/grub.conf
15、使用echo命令输出一个绝对路径,使用grep取出其基名;
echo “/etc/passwd/” | egrep -o “[[:alpha:]]+” | tail -n 1
扩展:取出其路径名
echo “/etc/passwd” | sed ‘s@[^/]\+/\?$@@’
16、显示当前系统root、centos或user1用户的默认shell和UID;
egrep ‘^(root|centos|user1)\>’ /etc/passwd | cut -d: -f1,3,7
17、找出/etc/rc.d/init.d/functions文件(centos6)中某单词后面跟一个小括号的行;
egrep -o “^[_[:alpha:]]+\(\)” /etc/rc.d/init.d/functions

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/86847

(1)
thinkingthinking
上一篇 2017-09-10 19:10
下一篇 2017-09-10 20:27

相关推荐

  • nginx学习笔记

    深入理解Nginx 一、Nginx是什么? 二、为什么选择Linux ? 三、Nginx生成的文件有哪些? 四、Nginx的配置详解? 五、模块功能详解 六、虚拟主机配置详解?                 一、Nginx是什么? Nginx(engine X)是一个高性能的H…

    Linux干货 2017-03-15
  • 4、文件通配和权限

    http://note.youdao.com/yws/public/redirect/share?id=bc0a93cca15963ed8490649892b2c31d&type=false

    Linux干货 2016-08-08
  • 如何删除一个目录下的所有文件,但保留一个指定文件。附一些常用命令

    解答: 假设这个目录是/xx/,里面有file1,file2,file3..file10   十个文件 方法如下: find /date -type f ! -name “file10″|xargs rm -f 另外还有其他的方法比如:rsync命令和bush的 extglob功能等。在此不一一列举。 附常用命令: 文件和目…

    2017-07-15
  • 用户管理、三种权限、三种特殊权限的使用

    用户管理、三种权限、三种特殊权限的使用 一、用户管理 1、软链接:ln  -s  相对于软链接的路径/绝对路径   软链接文件    硬链接:ln  相对路径原文件   硬链接文件 2、getent的使用    gentent p…

    系统运维 2016-08-05
  • N25-第六周

    请详细总结vim编辑器的使用并完成以下练习题 1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;      cp /etc/rc.d/rc.sysinit /tmp     &nbsp…

    Linux干货 2017-03-08
  • Linux的诞生史

    Linux诞生史 远古记忆-UNIX的诞生 Multics计划—开始 这是由麻省理工学院,通用电气和AT&T的贝尔实验室合作的操作系统项目,用于使用在GE-645大型主机上的。但是由于整个目标过于庞大,Multics虽然发布了一些产品,但是性能都很低,AT&T退出了Mulitcs项目,计划终止。肯.汤姆逊当时也参加了这个项目,很不…

    2017-07-11