grep、egrep正则表达式之初窥门径

何谓正则表达式

正则表达式,又称正规表示法、常规表示法(Regular Expression,在代码中常简写为regex、regexp或RE),是一类字符所书写的模式,其中许多字符不表示其字面意义,而是表达控制或通配等功能。正则表达式使用单个字符串来描述、匹配一系列符合某个句法规则的字符串。在很多文本编辑器里,正则表达式通常被用来检索、替换那些符合某个模式的文本。许多程序设计语言都支持利用正则表达式进行字符串操作。

正则表达式语言由两种基本字符类型组成:原义(正常)文本字符和元字符。元字符使正则表达式具有处理能力。所谓元字符就是指那些在正则表达式中具有特殊意义的专用字符,不表示其字面意义,而用于额外功能性描述。

正则表达式分类

正则表达式根据元字符的数量及功能不同又分为基本正则表达式(grep)和拓展正则表达式(egrep)。而grep和egrep同属于文本搜索工具,可根据用户指定的文本模式(搜索条件)对目标文件进行逐行搜索,显示能匹配到的行。用法上grep –E等同于egrep,与grep和egrep相似的文本搜索工具还有fgrep,因不支持使用正则表达式,所以不再单独介绍。

基本正则表达式(grep)

语法格式:grep[option]… ‘PATTERN’ FILE…

基本正则表达式元字符:

1.字符匹配:

 .:任意单个字符
[ ]:匹配指定范围内的任意单个字符
[0-9]:匹配单个数字
[a-z]:匹配单个小写字母
[A-Z]:匹配单个大写字母
[[:digit:]]:匹配单个数字
[[:lower:]]:匹配单个小写字母
[[:upper:]]:匹配单个大写字母
[[:space:]]:匹配单个空白字符
[[:punct:]]:匹配单个标点符号
[[:alnum:]]:匹配单个字母或数字
[[:alpha:]]:匹配单个字母(不分大小写)
[^]:匹配范围外的任意单个字符

2.次数匹配

*:任意次(前面字符出现任意次)
\?:0次或1次(前面字符可有可无)
\{m\}: m次(前面字符出现m次)
\{m,n\}:至少m次,至多n次
\{m,\}:至少m次
\{0,n\}:至多n次
.*:任意长度的任意字符

3.位置锚定:

^:行首锚定(写在模式最左侧)
$:行尾锚定(写在模式最右侧)
^$:空白行
\<,/b:词首锚定(出现于单词左侧)
\>,/b:词尾锚定(出现于单词右侧)
(注:不包含特殊字符的连续字符组成的串叫单词)

4.分组

 \( \):如\(ab\)*
(分组中的模式匹配到的内容,可由正则表达式引擎记忆在内存中,之后可被引用)

5.引用

\n:引用前面的第n个左括号以及与之对应的右括号中的模式所匹配到的内容

拓展正则表达式(egrep)

语法格式:egrep [option] ‘PATTERN’ FILE…

拓展正则表达式元字符:

1.字符匹配:

 .:任意单个字符
[ ]:匹配范围内的任意单个字符
[^]:匹配范围外的任意单个字符

2.次数匹配:

*:任意次
?: 0或1次
+:至少1次
{m}: m次
{m,n}:至少m次,至多n次
{m,}:至少m次
{0,n}:至多n次

3.位置锚定:

^:行首锚定
$:行尾锚定
\<,\b:词首锚定
\>,\b:词尾锚定
^$,^[[:space:]]*$:空白行

4.分组

( ):分组
|:或 

5.引用:

\n:引用前面的第n个左括号以及与之对应的右括号中的模式所匹配到的内容

grep及egrep命令选项

-v: 反向选取
 -o:仅显示匹配的字串,而非字串所在的行
-i:ignore-case,忽略字符大小写
-A:显示之前两行
-B:显示之后两行
-C:显示上下两行

牛刀小试

 显示/proc/meminfo文件中以大写或小写S开头的行

grep、egrep正则表达式之初窥门径

 显示/etc/passwd文件中其默认shell为非/sbin/nologin的用户

grep、egrep正则表达式之初窥门径

显示/etc/passwd文件中其默认shell为/bin/bash的用户中ID号最大的用户

grep、egrep正则表达式之初窥门径

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

grep、egrep正则表达式之初窥门径

显示/boot/grub/grub.conf中以至少一个空白字符开头的行

grep、egrep正则表达式之初窥门径

显示/etc/rc.d/rc.sysinit文件中,以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行

 grep、egrep正则表达式之初窥门径

找出netstat -tan命令执行结果中以’LISTEN’结尾的行

grep、egrep正则表达式之初窥门径

找出当前系统上其用户名和默认shell相同的用户

grep、egrep正则表达式之初窥门径

显示当前系统上root或scholar用户的默认shell

grep、egrep正则表达式之初窥门径

找出/etc/rc.d/init.d/functions文件中某单词后跟一组小括号“()”行 grep、egrep正则表达式之初窥门径

使用echo命令输出一个路径,而后使用grep取出其基名 grep、egrep正则表达式之初窥门径

找出ifconfig命令结果中的1-255之间的数字 grep、egrep正则表达式之初窥门径

The End


    好了总结到这里,常用的正则表达式用法就整理的差不多了,以上都是个人学习总结,如有错漏,大

神勿喷~~~

原创文章,作者:书生,如若转载,请注明出处:http://www.178linux.com/1198

(0)
书生书生
上一篇 2015-03-19
下一篇 2015-03-19

相关推荐

  • 磁盘和文件系统创建

    磁盘结构:主要是由盘体、控制电路、接口部件等组成。盘体里面封装了多个盘片的腔体;控制电路包含硬盘BIOS、主控芯片和硬件缓存等单元;接口部件包含电源、数据接口主从跳线等。读取硬盘数据时,主轴电机带动盘片旋转,副轴电机带动磁头臂将磁头放到相应的数据存放的柱面和磁道上,再由磁头读出相应扇区中的数据。(图1-1) 磁道(track):每个盘面被划分成了多个同心圆环…

    Linux干货 2016-02-14
  • 免费翻墙 [精]

    本人在hostus上买了一个国外的vps,花了一上午把Google给做好,可以访问g.abcdocker.com进行搜索,因为是使用nginx代理进行翻墙。网上的文章也很乱,很不好整理。 可以可以使用g.abcdocker.com上Google查阅资料。(无法观看视频) www.abcdocker.com

    2017-06-17
  • grep与正则表达式

    一、grep        grep常用于文本搜索。通过自定义的模式(pattern),筛选出使用者需要的文本内容。除了有grep,还有egrep和fgrep。其中egrep = grep  –E,而fgrep则是不支持正则表达式。     &nbs…

    2017-07-29
  • 系统自动化安装

    系统自动化安装:实现同时部署多台操作系统,批量进行安装linux系统 CentOS系统安装     系统启动流程:       bootloader–>kernel(initaramfs)–>rootfs–>/sbi…

    Linux干货 2016-09-22
  • 可伸缩的逻辑卷

    什么是逻辑卷? 逻辑卷简称LVM, LVM是Linux环境中对磁盘分区进行管理的一种机制,是建立在硬盘和分区之上、文件系统之下的一个逻辑层,可提高磁盘分区管理的灵活性.   为什么要使用逻辑卷? 逻辑卷相比于一般的磁盘分区, 具有更高的灵活性。可随时伸缩空间的大小.   构建逻辑分区图:   逻辑卷概念: PV(物理卷): 是在…

    Linux干货 2016-09-01
  • 第十周作业

    1、请详细描述CentOS系统的启动流程(详细到每个过程系统做了哪些事情) 2、为运行于虚拟机上的CentOS 6添加一块新硬件,提供两个主分区;   (1) 为硬盘新建两个主分区;并为其安装grub; #创建两个分区,/dev/sdb1为500M,/dev/sdb2为5G [root@centos6 mnt]# fdisk -l /dev/sdb…

    2017-03-12

评论列表(3条)

  • stanley
    stanley 2015-03-19 21:46

    重点突出,分类得当,标签精确,图文并茂,不得不赞!

    • 书生
      书生 2015-03-19 22:58

      @stanley谢大神抬爱 :roll: :roll: :roll:

    • stanley
      stanley 2015-03-23 18:29

      @书生hi,同学加下我qq,你文章的图床有问题,我找不到你个人信息联系不上你