Grep 文本搜索工具与正则表达式

        grep (缩写来自Globally search a Regular Expression and Print)是一种强大的文本搜索工具,它能使用特定模式匹配(包括正则表达式)搜索文本,并默认输出匹配行。Grep在实际中对于我们的工作有着很大的作用,用于对文件的搜索,通过由正则表达式字符以及文本字符所编写的过滤条件来获取我们想要查找的行或关键信息。

Grep语法

  grep
[OPTIONS] PATTERN [FILE…]     
  

             -n :显示行号

-i :忽略字符的大小写

-o :仅显示匹配到得字符串

-e :指定多个匹配条件(或的关系)

-c :显示统计到的行数   类似于 wc -l 的功能

-v :取反功能,匹配出不包含“PATTERN”的行

-q :静默输出,不输出任何信息,只关心执行结果

-A # after,匹配到的行的后#

-B #  :  before,匹配到的行前#

-C # context,匹配到得行前后各#

-E ==egrep 支持扩展的正则表达式   -F ==fgrep,快速搜索

而且egrepfgrep的命令只跟grep有很小不同。egrep和fgrep都是grep的扩展,支持更多的re元字符,fgrep就是fixed
grep或fast grep,它们把所有的字母都看作单词,也就是说,正则表达式
中的元字符表示回其自身的字面意义,不再特殊。linux使用GNU版本的grep。它功能更强,可以通过-E、-F命令行选项来使用egrep和fgrep的功能。

grep的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到屏幕,不影响原文件内容。

grep可用于shell脚本,因为grep通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文件不存在,则返回2。我们利用这些返回值就可进行一些自动化的文本处理工作。

Grep命令中允许指定的串语句是一个规则表达式,这是一种允许使用某些特殊键盘字符的指定字符串的方法,这种方法中的特殊键盘字符可以用于代表其他字符也可以进一步定义模式匹配工作方式。例如:grep “.*hood” essay1。该命令将在文件essay1中搜索,显示出包含带有字符串hood的字的每一行。命令行中的点表示的是hood之前可以有任意字符,星号指的是在字符串之前点号所表示的任意字符可以有任意个其中的双引号是可有可无的,但是当语句中包含短语或者空格时就必须加双引号

         正则表达式分为两类

                            基本正则表达式:BRE

                            扩展正则表达式:ERE

基本正则表达式

字符匹配

      . :匹配任意单个字符;

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

         有以下几种表示方法:

                                               [:digit:] :表示所有数字;

                                               [:upper:]: 表示所有大写字母;

                                               [:lower:]:表示所有小写字母;

                                               [:alpha:]:表示所有的字母;

                                               [:alnum:]:表示所有的字母和数字;

                                               [:punct:]:表示所有的标点符号;

                                               [:space:]:表示所有的空白字符;

                                               [1-9]:表示19的数字,包括19

                                               [a-z]:表示为 a A b B c C … z Z中任意一个字母。

[^] : 匹配除指定范围内的任意单个字符;例如:[^zhang]:表示除zhang之外的字母

     次数匹配

     *:表示匹配前面的字符任意次;(贪婪模式,能匹配多少就匹配多少)

         例如:grep  “x*y” ———可以是xayxcsy,也可以是x2aty,但是x不可以,y不可以。

    .* : 表示任意长度的任意字符;

    \?: 表示匹配前面的字符01次,即可有可无;

    \+: 匹配前面的字符至少一次;

    \{m\}: 匹配前面的字符m次;

    \{m,n\}: 匹配前面的字符至少m次,最多n次;

    \{m,\}:匹配前面的字符至少m次;

    \{0,n\}: 匹配前面的字符最多n次。

    位置锚定

    对特定位置进行定位

             ^
:
行首锚定; $: 行尾锚定;—— ^$ 表示匹配空白行(不包含空格);^[[:space:]]$ 包含空格的空行。

             \<\b :词首锚定; \>\b :词尾锚定 —— 例如:\<PATTERN\> 匹配整个单词

 

    分组

             分组是将多个字符捆绑在一起,当做一个整体进行处理:\( \)  例如:\(xy\)* 表示xy这个整体可以出现任意次 ,后边用\1,\2..来分别表示之前从左边开始括起来的每一组  

 示例:      

1、显示/proc/meminfo文件中以s(不区分大小写)开头的行

Grep 文本搜索工具与正则表达式

Grep 文本搜索工具与正则表达式

Grep 文本搜索工具与正则表达式

2、显示/etc/passwd文件中其默认shell不是/sbin/nologin的用户

Grep 文本搜索工具与正则表达式

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

Grep 文本搜索工具与正则表达式

Grep 文本搜索工具与正则表达式

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

Grep 文本搜索工具与正则表达式

5、找出当前系统上用户ID和属组ID相同的用户

Grep 文本搜索工具与正则表达式

扩展正则表达式

   grep
–e ‘PATTERN’ FILE…

   egrep
‘PATTERN’ FILE…

       字符匹配字符锚定与基本正则相同

         次数匹配

                   ?:表示01次;

                   +:至少一次;

                   {m}:精确匹配m次;

                   {nm}:至少m次,最多n次;

                   {0m}:最多m次;{n}:至少n次。

                   其他与基本相同

         或者

                a|b

         分组()括号无需转义。

示例:

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

Grep 文本搜索工具与正则表达式

原创文章,作者:Immortals、zcy,如若转载,请注明出处:http://www.178linux.com/73360

(0)
上一篇 2017-04-15 17:26
下一篇 2017-04-16 09:46

相关推荐

  • 马哥教育网络班20期第3周课程练习

    答: 1、 [root@totooco ~]# who | cut -c1-9 | sort -u 2、 [totooco@totooco ~]$ who | cut -c1-9 | head -1 3、 [root@totooco ~]# cat /etc/passwd | cut -d: -f7 | grep -v /sbin/nologin | sor…

    Linux干货 2016-06-23
  • 绝对路径和相对路径及cd、pwd、mkdir、rmdir、tree命令

    绝对路径和相对路径及cd、pwd、mkdir、rmdir、tree命令详解 一、绝对路径和相对路径(由下图进行讲解) 绝对路径:由根目录开始(/)开始的文件名或者目录名称,我们通过绝对路径切换到/man1文件处,所经过的路径。 cat /root/usr/share/man/man1 如下图 相对路径:相对于当前路径,以当前所在位置的相对路径。例如…

    Linux干货 2016-08-02
  • 全面解析文件文件系统

    前言: 文件系统作为linux总最基础的但愿。理解并深入了解文件系统对linux的学习有重要意义。我们从文件系统创建,构成以及工作流程几个方面全方位的介绍文件系统的相关概念。 简述: 一块完整的磁盘经过分区后我们就可以通过格式化,根据我们的需求构建文件系统能使用的文件系统格式。传统的文档系统中,一个分区就只能够被格式化为一个文件系统。所以我们可以说一个文件系…

    Linux干货 2016-11-14
  • Linux运维学习历程-第八天-Linux文本工具sed与Vim(vi)

    概述:    本篇我们主要学习两个功能非常强大的文本编辑器,了解这两种文本编辑器的各自的特点 一、sed命令:  1、sed简介:     sed(Stream EDitor)是一种流编辑器、行编辑器。逐行处理文本内容,即一次处理一行内容,处理时,当前处理的行存储在“模式空间”(pattern sp…

    Linux干货 2016-08-15
  • 开篇

    正式开始学习的第一天,了解LINUX,爱上LINUX。希望在往后的日子里越战越勇!!

    Linux干货 2017-07-11
  • 马哥教育网络班21期-第九周课程练习

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash m=0 n=0 for i in `awk -F: '{print $NF}'&nb…

    Linux干货 2016-09-15

评论列表(1条)

  • renjin
    renjin 2017-04-21 11:19

    主要介绍了grep命令的详细用法及示例说明,内容总结的很详细,排版也很好。继续努力 !