博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
grep、egrep、fgrep的用法与特性详解
阅读量:5020 次
发布时间:2019-06-12

本文共 4821 字,大约阅读时间需要 16 分钟。

[转载自]http://tanxw.blog.51cto.com/4309543/1361993

开篇

       学习Linux也有一段时间了,对Linux多少也算是有点了解了,越是了解也就越对这个系统有兴趣,从0基础开始,已经学习了两周了吧,说实在的,很 多的东西都是逻辑的问题,而学习Linux就是要熟悉命令,命令很多,要记的东西也很多,多得可以你让头皮发麻,不过话又说回来了,既然选择了这门技术, 那就义无反顾的去做好做专,好了,总结一下这两周来感觉学起来比较用力的部分。

 

正文之:grep的详细介绍

       grep和egrep是现在感觉比较难的一部分,主要是符号多,看得眼花了乱。
       grep(global search regular expression and prind out the line)全称就叫全面搜索正则表达式 并打印行出来,简单来说就是文本搜索工具,根据用户指定的文本搜索模式对目标文本进行搜索,显示能够所匹配的行,当然,也可以把grep看也是一个文本过 虑器。
       格式:grep [options]... 'PATTERD模式' file....
       模式:就是一个最基本的字符串    
       如:grep –A 1 '[r][[:punct:]]*[t]' /etc/passwd  ''里的内容就是模式
grep的常用选项:
       -v:反向匹配、显示不能别模式匹配到的行;
       例:取出/etc/fstab不包含#号的行
       gerp –v "#" /etc/fstab

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
[root@localhost xiao]
# cat /etc/fstab
#
# /etc/fstab
# Created by anaconda on Mon Feb 10 10:38:04 2014
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
/dev/mapper/vg0-root   
/                       ext4    defaults        1 1
UUID=99e81364-46cb-4795-974a-6cc0ab91a46f
/boot                  
ext4    defaults        1 2
/dev/mapper/vg0-usr    
/usr                   
ext4    defaults        1 2
/dev/mapper/vg0-var    
/var                   
ext4    defaults        1 2
/dev/mapper/vg0-swap   
swap                    swap    defaults        0 0
tmpfs                  
/dev/shm               
tmpfs   defaults        0 0
devpts                 
/dev/pts               
devpts  gid=5,mode=620  0 0
sysfs                  
/sys                   
sysfs   defaults        0 0
proc                   
/proc                  
proc    defaults        0 0
[root@localhost xiao]
# grep -v "#" /etc/fstab
/dev/mapper/vg0-root   
/                       ext4    defaults        1 1
UUID=99e81364-46cb-4795-974a-6cc0ab91a46f
/boot                  
ext4    defaults        1 2
/dev/mapper/vg0-usr    
/usr                   
ext4    defaults        1 2
/dev/mapper/vg0-var    
/var                   
ext4    defaults        1 2
/dev/mapper/vg0-swap   
swap                    swap    defaults        0 0
tmpfs                  
/dev/shm               
tmpfs   defaults        0 0
devpts                 
/dev/pts               
devpts  gid=5,mode=620  0 0
sysfs                  
/sys                   
sysfs   defaults        0 0
proc                   
/proc                  
proc    defaults        0 0

 

       -o:仅匹配被模式匹配到的字串,而非整行,就是仅显示匹配到的内容

       例:只显示/etc/fstab为mapper的字串
       grep -o "mapper" /etc/fstab

1
2
3
4
5
[root@localhost xiao]
# grep --color=auto -o "mapper" /etc/fstab
mapper
mapper
mapper
mapper

 

       -i:不区分大小写对文本进行匹配搜索

       wKioL1MIRVWwAigMAABuWOYUTi0180.jpg

       -E:支持扩展正则表达式
       -A #:显示模式匹配到的行以及后面的N行 #代表你要显示多少行

       例:显示/etc/passwd中shutdown用户后面3行

       wKiom1MIJFbBJB0TAADVEQp00Vw654.jpg

       -B #:显示模式匹配到的行以及前面的N行

       例:显示/etc/passwd中shutdown用户上面2行

       wKioL1MIJQCgbbqwAACoQoIIoQM153.jpg

       -C #:显示模式匹配到的行以及上下的N行

       例:显示/etc/passwd中shutdown用户上下面2行

       wKiom1MIJZOwuHJlAAC-Tllmg7k700.jpg

 

   其实,要用好grep的强大搜索功能,那就不得不说说正则表达式了:

   正则表达式就是一类字符所书写出来的模式(pattern)、正则表达式基本上都是由元字符组成;
   那什么是元字符呢:元字符不表示字符本身的意义,而是用于额外功能性的描述。
   基本正则表达式的元字符:学习正则表达式主要是来学习其元字符的用法后慢慢组合这些元字符来表达到正则表达式的使用,grep在默认情况下只支持基本正则表达式。
注意:
   模式当中一但包含元字符一定要用''或""号引起来,单双引号都可以、只不过如果其中出现了变量、并且我们希望做变量替换的话那就要使用""双引号了、否则可以不加区分的使用。
   那就来说说元字符的通配:
       .(点号):匹配任意的单个字符的
       例:grep "r..t" /etc/passwd
       rt加上两点被匹配到的只有4个字符,点号表示的是单个字符

       wKiom1MIMODQF-6wAACjXrjomz0277.jpg

      []:指定范围内的任意的单个字符
           [0-9] [[:digit:]]:表示匹配0到9的任意单个数字、两种表示方法都可以
           [a-z] [[:lower:]]:表示匹配小写的a到z的任意单个字母、即a-z
           [A-Z] [[:upper:]]:表示匹配大写的A到Z的任意单个字母、即A-Z
           [[:alpha:]]:表示英文大小写字母、即:a-z,A-Z
           [[:space:]]:表示包含的空白字符、即空格键,tab键
           [[:alnum:]]:表示包含数字大小写字母、即0-9,A-Z,a-z
           [[:punct:]]:表示包含标点符号、即:" ' ? ! ; : # $...

 

       例:显示/etc/fstab下含有数字的行

       grep --color [0-9] /etc/fstab

       wKiom1MIMcKyjJx6AAHGRgi8BNg162.jpg

 

       例:显示/etc/fstab中包含大写字母的行

       grep --color "[[:upper:]]" /etc/fstab        

       wKioL1MIMqmSV3XFAAEXjoMqCFg545.jpg

    [^]:表示指定范围外的任意单个字符、就是使用了脱字符取反

        例:显示/etc/fstab中数字以外的内容

        grep --color [^[:digit:]] /etc/fstab

       wKioL1MINR-jMVKxAAHcomJRJkQ071.jpg

   字符的次数匹配:用来匹配其前面的字符的次数的
           *:(星号)匹配其紧挨着星号的字符出现任意次
               例:x*y就是x可以出现意次、包括0次
           .*:(点星)匹配任意长度的任意字符
           \?:表示其前面的字符出现0次或者1次、\是转译字符
               例:x\?y:可以匹配到的只有xy和y
           \{m\}:匹配m次  如:x\{4\}y表示y前面的x出现4前就可以被匹配到
           \{m,n\}:至少m次,至多n次
           \{m,\}:至少m次
           \{0,n\}:至多匹配n次、0不可以省略

 

            例:找出/etc/fstab文件中一位数或两位数

           grep --color '\<[0-9]\{1,2\}\>' /etc/fstab

           \{1,2\}:表示0-9的数字出现的至有1位、至多有2位、

           wKioL1MINz-C9BQNAAGLPoJJ2qQ535.jpg

   位置锚定符:用于指定字符出现的位置
           ^:用于锚定行首,如(^Char) 匹配到的字符必须出现有行首的
           $:用于锚定行尾,如(Char$) grep 'bash$' /etc/passwd
           ^$:空白行、查找一个文件中所出现的空白行  ^hello$表示只有hello的行

 

           例:显示/etc/fstab中以#号开头的行

           grep --color "^#" /etc/fstab

           wKiom1MIOU_D3iLmAADoBRKfGD8531.jpg

   单词的锚定:
           \<char:锚定词首,\<[r]表示一行以r开头的单词都可以匹配、也可以使用\b表示
           char\>:锚定词尾,一行以r开头的单词都可以匹配、\b
           \<hello\>:表示精确锚定hello这个单词
           \<h…o\>:表示以h开头、以o结尾、中间跟了任意三个字符的单词

 

           例:显示/etc/passwd中以stu开头的单词

           grep --color "\<stu" /etc/passwd     只要是以stu开头的单词都会被匹配到

           wKioL1MIOomhPD_NAAGB9xe3l0Y589.jpg

 

   分组元字符:

           \(\):分组  \是转译字符  
           例:\(ab\)*xy
           ab括起来表示一个组了,表示xy前面的ab组现出任意次,可以被匹配到的
           abxy,ababxy,ababababxy,abababababababxy,......
   引用: 对分组的字符块进行引用
           \1:后向引用,引用前面的第一个左括号以及与之对应的右括号中模式所匹配到的内容
           \2:后向引用,引用前面的第二个左括号以及与之对应的右括号中模式所匹配到的内容
           .......

           例:\(a.b\)xy\1 可以匹配到的有(abxyab不可以匹配到)
           akbxyakb,a3bxya3b,aYbxyaYb

           例:我们来看这个例子、找出以下love与之对应的lover、like与之对应的liker

           He like his lover.

           She love her liker.
           He love his lover.
           She like her liker.

          wKiom1MIThPBv5PAAABjf81TDQo797.jpg

 

正文之:egrep的详细介绍

       egrep:使用扩展正则表达式来构建模式,相当于grep –E、通常写成egrep、用法基本上跟grep的相同、只是有些不需要\转译
   元字符:字符匹配

          .:匹配任意单个字符

          []:指定范围内的任意单个字符
   次数匹配:
          *:匹配其紧挨着星号的字符出现任意次
          ?:表示其前面的字符出现0次或者1次
          +:匹配其前面的字符至少1次
          {m}:匹配其前面的字符m次
          {m,n}:至少m次,至多n次
          {m,}:至少m次
          {0,n}:至多n次

 

        例:找出/etc/fstab文件中一位数或两位数

       egrep --color '\<[0-9]{1,2}\>' /etc/fstab  {}不需要转译

       wKioL1MIP6PDdqM_AAHTjWq39Sc923.jpg

   做位置锚定:
        ^:行首锚定
        $:行尾锚定
        \<:词首
        \>:词尾
   分组:
       ():分组
       |:或者  ab|xy意思为ab或者xy  a(b|x)y意思为aby或者axy
正文之:fgrep的详细介绍
   fgrep:fash,它不解析正则表达式、想找什么就跟什么就可以了;
       例:
       fgrep "/bin/bash" /etc/passwd

 

       例:显示/etc/fstab中含有defaults的行

       fgrep --color "defaults" /etc/fstab

       wKiom1MIQOHxaJCCAAE_77vJH6U784.jpg

 

结束

       常用的大概的内容应该就这些吧,这些都是学习当中的基本用法和我个人的笔记,总结并记下,以便以后查找,同时,虽然是刚学习的,也希望我个人的总结可以帮到更多的人,哦了,不多说了,就总结到这里了,欢迎大神来指点。

转载于:https://www.cnblogs.com/tanxw/p/3791079.html

你可能感兴趣的文章
程序员面试、算法研究、编程艺术、红黑树4大系列集锦与总结 .
查看>>
idea tomcat 配置
查看>>
冲刺第二天
查看>>
LeetCode 405. Convert a Number to Hexadecimal (把一个数转化为16进制)
查看>>
ASP.NET MVC 3–Global Action Filters
查看>>
OFFICE安装提示1935错误
查看>>
jva基础网络编程
查看>>
js 正计时和倒计时
查看>>
复合数据类型,英文词频统计
查看>>
you-get帮助使用手册
查看>>
nyoj756_重建二叉树_先序遍历
查看>>
sin()函数的实现
查看>>
图像切割之(一)概述
查看>>
JAVA修饰符类型(public,protected,private,friendly)
查看>>
flex利用webservice上传照片
查看>>
IOS开发之Bug--使用KVC的易错情况
查看>>
python list和tuple
查看>>
基础薄弱的反思
查看>>
ORACLE增删改查以及case when的基本用法
查看>>
[转]oracle10客户端PL/SQL Developer如何连接远程服务器上的oracle数据库
查看>>