正则表达式及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

相关推荐

  • rsyslog同步history日志

    前言   由于公司业务是由公司内部开人员及外包团队共同开发,所以需要使用rsyslog对history日志做收集、审计。虽然搭建及配置非常简单,但是在日常运维工作中很实用,所以记录下,方便日后快速搭建。如果有错误,望大神指正。 syslog简介 syslog是Linux系统默认的日志守护进程。默认的syslog配置文件是/etc/sysl…

    Linux干货 2015-04-03
  • 03硬链接和软链接的区别和联系

    首先我们需要了解linux下硬链接以及软连接的基本概念. 硬链接:新建的文件是已经存在的文件的一个别名,当原文件删除时,新建的文件仍然可以使用. 软链接:也称为符号链接,新建的文件以“路径”的形式来表示另一个文件,和Windows的快捷方式十分相似,新建的软链接可以指向不存在的文件. 硬链接和软连接之间的区别: 1.硬链接和原来的文件没有什么区别,而且共享一…

    Linux干货 2016-10-20
  • vsftpd 配置文件的一些设置

    ftp:File Transfer protocol 文件传输协议 两个连接: tcp:命令连接 tcp:数据连接 主动模式:服务器端通过20端口主动连接客户端,客户端监听在于服务器端的建立连接的端口+1上,服务器工作在tcp/20 被动模式:客户端使用自己与服务器端建立端口+1上连接客户端的随机端口 防火墙上连接追踪 数据要流失化文本:文件流二进制 c/s…

    Linux干货 2017-09-10
  • 初识SElinux

    一、SElinux(Secure Enhanced Linux):安全增强的Linux        SElinux是一个在内核中实践的强制访问控制(MAC)安全性机制,由美国国家安全局NSA(The National Security Agency)和SCC(Secure Computing Co…

    Linux干货 2016-09-15
  • 编译安装MariaDB源码包

        因为MySQL的发展趋势不甚乐观,MariaDB已替代MySQL被CentOS 7做为默认组件,如果想在CentOS 6中使用最新的MariaDB,则需要我们手动安装,其安装方式有三种:     1、RPM包安装     2、二进制…

    Linux干货 2015-06-08
  • 马哥教育网络班22期+第十二周课程练习

    1、请描述一次完整的http请求处理过程。    (1) 客户端与服务端通过TCP三次握手建立或处理连接:接收请求或拒绝请求    (2) 接收请求:接收来自于网络上的主机请求报文中对某特定资源的一次请求的过程    (3) 处理请求:对请求报文进行解析,获取客户端请求…

    Linux干货 2016-12-29

评论列表(1条)

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

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