正则表达式及grep使用

正则表达式分为:“基本正则表达式 BRE”跟“扩展正则表达式 ERE”

基本正则表达式:

    (1)字符匹配    

          "."任意单个字符

           "[]"匹配指定范围内的单个字符

          "[^]"匹配字符以外的单个字符

    (2)次数匹配

          "*"匹配前面字符的任意次 (.*:组合就相当于glob中的"*"匹配任意字符任意次)

          "\?"匹配前面的字符0次或1次;"\+"匹配前面的字符至少1次

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

    (3)位置锚定

          "^"行首;"$"行尾;("^$":真空行,什么都没有。 "^[[:space:]]*$"有空白字符的空行。)

          "\<"或"\b"词首;"\>"或"\b"词尾;

    (4)分组

         "\(\)"将一个或多个字符捆绑在一起,当一个整体处理;

         "\1"后项引用,引用从左向右数第一个分组所匹配到的字符;以此类推"\2"就是第2个分组所匹配到的字符,"\3"就是第三个….

    blob.png(图很丑看明白就好,哈哈..)

        注意:后项引用是直接使用前一个分组已经匹配出来的字符结果,而次数匹配的是相当于在做1次或多次匹配

扩展正则表达式:

    (1)字符匹配    

          "."任意单个字符

           "[]"匹配指定范围内的单个字符

          "[^]"匹配字符以外的单个字符

    (2)次数匹配

          "*"匹配前面字符的任意次 (.*:组合就相当于glob中的"*"匹配任意字符任意次)

          "?"匹配前面的字符0次或1次;"+"匹配前面的字符至少1次

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

    (3)位置锚定

          "^"行首;"$"行尾;("^$":真空行,什么都没有。 "^[[:space:]]*$"有空白字符的空行。)

          "\<"或"\b"词首;"\>"或"\b"词尾;

    (4)分组

         "()"将一个或多个字符捆绑在一起,当一个整体处理;

         "\1"后项引用,引用从左向右数第一个分组所匹配到的字符;以此类推"\2"就是第2个分组所匹配到的字符,"\3"就是第三个….

    (5)或者   "|" a|b:a或者b

           A|asd:A或者asd

            (cai)|(CA)I:cai或者CA


        大部分跟正则表达式相同,有些只是去掉"\"反斜线逃。

        正则表达式默认工作在贪婪模式下。

grep:是一个可以使用正则表达式搜索匹配的文本过滤工具,使用正则表达式可以做到匹配出很多“glob”匹配不出的内容。

       
            grep [OPTIONS] PATTERN [FILE...]
            grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]
                        选项:
                                                        --color=auto: 对匹配到的文本着色显示;
                                                        -v: 显示不能够被pattern匹配到的行;
                                                        -i: 忽略字符大小写;
                                                        -o: 仅显示匹配到的字符串;
                                                        -q: 静默模式,不输出任何信息;
                                                        -A #:after, 后#行
                                                        -B #: before, 前#行
                                                        -C #:context, 前后各#行
                                                        -E:使用ERE;

grep使用演示:

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

# grep -i "^s" /proc/meminfo 
# grep "^[Ss]" /proc/meminfo
# grep "^S" /proc/meminfo && grep "^s" /proc/meminfo (感谢“N21-蓝”妹子的细心实验检查,这个答案是有问题的,各位可以看下有什么问题检验一下自己。)

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

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

3、显示/etc/passwd文件中ID号最大的用户的用户名;

# sort -t: -k3 -n /etc/passwd | tail -1 | grep -o "^[[:alnum:]]\+\b"
# sort -t: -k3 -n /etc/passwd | tail -1 | grep -o -E "^[[:alnum:]]+\b"

4、如果用户root存在,显示其默认的shell程序;

# id root &> /dev/null && grep "^root" /etc/passwd | cut -d: -f7

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

# grep "\b[0-9]\{2,3\}\b" /etc/passwd
# grep -E "\b[0-9]{2,3}\b" /etc/passwd

6、显示/etc/rc.d/rc.sysinit文件中,至少以一个空白字符开头的且后面存非空白字符的行;

# grep "^[[:space:]]\+[^[:space:]]\+" /etc/rc.d/rc.sysinit

7、找出"netstat -tan"命令的结果中以'LISTEN'后跟0、1或多个空白字符结尾的行;

# netstat -tan | grep --color "LISTEN[[:space:]]*"

8、添加用户bash、testbash、basher以及nologin(其shell为/sbin/nologin);而后找出/etc/passwd文件中用户名同shell名的行;

这题我使用bash脚本
#!/bin/bash
id bash &> /dev/mull || useradd bash
id testbash &> /dev/null || useradd testbash
id basher &> /dev/null || useradd basher
id nologin &> /dev/null || useradd -s /sbin/nologin nologin
grep --color "^\(\b[[:alnum:]]\+\b\).*\1$" /etc/passwd
#grep --color -E "^(\b[[:alnum:]]+\b).*\1$" /etc/passwd

1、显示当前系统root、centos或user1用户的默认shell和UID;

# grep -E '^(root|centos|user1)\>' /etc/passwd | cut -d: -f1,3,7

2、找出/etc/rc.d/init.d/functions文件(centos6)中某单词后面跟一个小括号的行;

# grep -E -o "^[_[:alpha:]]+\(\)" /etc/rc.d/init.d/functions

3、使用echo输出一绝对路径,使用egrep取出其基名;

# echo "/mnt/sdc" | grep -E -o "[^/]+/?$" | cut -d"/" -f1

4、找出ifconfig命令结果中1-255之间的数值;

# ifconfig | grep -E --color "\b[0-9]{1,2}\b|\b1[0-9]{1,2}\b|2[0-4][0-9]?|\b25[0-4]?"

5、找出ifconfig命令结果中的IP地址;

# ifconfig | grep -E --color "((\b[0-9]{1,2}\b|\b1[0-9]{1,2}\b|2[0-4][0-9]?|\b25[0-5]?)\b\.){3}(\b[0-9]{1,2}\b|\b1[0-9]{1,2}\b|2[0-4][0-9]?|\b25[0-5]?\b)"

原创文章,作者:N21_志建,如若转载,请注明出处:http://www.178linux.com/22226

(0)
N21_志建N21_志建
上一篇 2016-07-10
下一篇 2016-07-10

相关推荐

  • 第十五周作业

    1、总结sed和awk的详细用法; sed:     模式空间:sed是一种在线编辑器、行编辑器,一次处理一行内容,在处理时,把当前处理的行存储在临时缓冲区当中,并在该缓冲区中完成后续的处理,该缓冲区被称为”模式空间”。     保持空间:在模式空间中处理完一行内容后会继续处理下一行,但是对于处…

    Linux干货 2017-04-18
  • 基于Python和MoviePy库实现数据的动态展示

    基于Python和MoviePy库实现数据的动态展示 (翻译:以马内利)  原文链接:Data Animations With Python and MoviePy   Python拥有很多实现数据可视化的库,但是很少可以展示GIFs的动态视图。 这篇博客主要介绍怎样使用MoviePy库作为一个其他可视化库的通用插件。 Movi…

    2015-03-26
  • man命令的用法

    man 命令的用法    在linux运维工作中,经常会有一些命令我们不是很清楚它们的准确用法,这时候我们就需要去查询这些命令的用法,linux中就有很多文档帮助我们去了解这些命令的用法,其中就有一条命令man,下面我就总结一下它的用法。     man 是 manual 的简写,提供命令的帮助文件。   &…

    Linux干货 2017-02-17
  • 26期全程班-第六周博客作业

    请详细总结vim编辑器的使用并完成以下练习题 1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#; # cp /etc/rc.d/rc.sysinit /tmp # vim /tmp/rc.sysinit :%s@^\([[:space:]]\+\)@#\1@g 2…

    Linux干货 2017-03-07
  • Nginx 基础 (IO模型、编译安装、几大块配置文件详解)

    Nginx基础 前言 apache在设计的时候已经考虑了并发访问模型,select()机制可以响应1024个访问,但是当数量再大,千万级别的时候http就响应不过来了。这个时候,nginx的出现解决了这一个问题。nginx是一个安装简单、配置文件简单、占用内存少、稳定性高、处理并发能力非常强、灵活好用等有点聚集于一身的轻量级服务器。在Linux操作系统中,N…

    Linux干货 2016-12-24
  • CentOS 7上的性能监控工具

    Linux中基于命令行的性能监控工具:dstat、top、netstat、vmstat、htop、ss、glances 1、dstat – 多类型资源统计工具(需配置epel源)   该命令整合了vmstat,iostat和ifstat三种命令。同时增加了新的特性和功能可以让你能及时看到各种的资源使用情况,从而能够使你对比和整…

    Linux干货 2016-09-07

评论列表(1条)

  • 马哥教育
    马哥教育 2016-07-12 14:44

    写的很好,排版还可以在漂亮一点,加油