总结之:grep、egrep、fgrep的用法与特性详解

简介:

开篇
       学习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


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










本文转自 wei0164 51CTO博客,原文链接:http://blog.51cto.com/tanxw/1361993,如需转载请自行联系原作者
目录
相关文章
|
8月前
|
人工智能 量子技术 调度
别只盯着ChatGPT了,量子计算才是下一个能源“爆点”!
别只盯着ChatGPT了,量子计算才是下一个能源“爆点”!
303 17
|
11月前
|
关系型数据库 MySQL 数据库
MyEMS开源系统安装之数据库
本文详细讲解MyEMS的安装步骤,重点介绍数据库架构与脚本部署。MyEMS支持MySQL 8.0、MariaDB 10.5及SingleStore 7.0等数据库服务器。通过命令行或客户端工具执行SQL脚本完成安装,包括多个数据库(如myems_billing_db、myems_energy_db等)。此外,提供解决常见问题的方法,如“用户拒绝访问”、“COLLATE设置”和“MAX_ALLOWED_PACKET错误”。注意,不建议在生产环境中将数据库安装于Docker容器内。
302 1
|
8月前
|
安全 数据可视化 API
什么是低代码?为什么低代码开发很重要?
低代码开发是一种通过可视化工具和少量编码快速构建应用程序的方法,帮助企业提升开发效率、降低成本,应对开发人员短缺问题。它让非专业开发者也能参与应用创建,同时让专业开发者更专注于复杂项目。低代码平台支持业务流程自动化、客户体验优化等多类应用开发,助力企业加速数字化转型。
|
9月前
|
Shell 定位技术 Android开发
微信号要养多久才稳定?微信怎么定位假位置呢
作为专注社交平台技术研究的开发者,我在过去三年中累计维护过200+企业微信账号矩阵
|
人工智能 计算机视觉 开发者
SmartEraser:中科大推出图像对象移除技术,轻松移除照片中的不想要元素,保留完美瞬间
SmartEraser 是由中科大与微软亚洲研究院联合开发的图像编辑技术,能够精准移除图像中的指定对象,同时保留周围环境的细节和结构,适用于复杂场景的图像处理。
427 8
SmartEraser:中科大推出图像对象移除技术,轻松移除照片中的不想要元素,保留完美瞬间
|
前端开发 PHP 数据安全/隐私保护
知识付费系统源码 PHP
在数字经济背景下,知识付费成为新兴领域,尤其在线教育平台的兴起,使更多教育者通过知识付费系统销售课程,实现数字化转型与收入提升。开发此类平台需考虑众多技术细节和业务需求,如使用PHP语言实现支付功能,确保安全性、性能和可扩展性,选择合适的技术方案至关重要。
339 4
知识付费系统源码 PHP
|
机器学习/深度学习 TensorFlow 算法框架/工具
【大作业-02】水果蔬菜识别系统-基于tensorflow2.3开发
2021年6月18日,TensorFlow 2.3物体分类代码已修复并更新。本项目支持自定义数据集训练,包括基于CNN和Mobilenet的模型,后者准确率高达97%。提供了详细的CSDN教程、B站教学视频及数据集下载链接,帮助用户快速上手。项目还包括PyQt5构建的图形界面,方便用户上传图片进行果蔬识别。更多详情与代码可在Gitee获取。
514 0
【大作业-02】水果蔬菜识别系统-基于tensorflow2.3开发
用栈实现将一个十进制数值转换成八进制数值。即用该十进制数值除以8,并保留其余数;重复此操作,直到该十进制数值为0为止。最后将所有的余数反向输出就是所对应的八进制数值
这篇文章展示了如何使用栈(包括顺序栈和链栈)实现将十进制数值转换成八进制数值的方法,通过C语言编程演示了两种栈的实现方式和使用场景。
用栈实现将一个十进制数值转换成八进制数值。即用该十进制数值除以8,并保留其余数;重复此操作,直到该十进制数值为0为止。最后将所有的余数反向输出就是所对应的八进制数值
|
缓存 JavaScript 前端开发
Vue 3的事件监听缓存如何优化性能?
【10月更文挑战第5天】随着前端应用复杂度的增加,性能优化变得至关重要。Vue 3 通过引入事件监听缓存等新特性提升了应用性能。本文通过具体示例介绍这一特性,解释其工作原理及如何利用它优化性能。与 Vue 2 相比,Vue 3 可在首次渲染时注册事件监听器并在后续渲染时重用,避免重复注册导致的资源浪费和潜在内存泄漏问题。通过使用 `watchEffect` 或 `watch` 监听状态变化并更新监听器,进一步提升应用性能。事件监听缓存有助于减少浏览器负担,特别在大型应用中效果显著,使应用更加流畅和响应迅速。
585 1
阿里云国际版账户收到账号风险通知,怎么办?
阿里云国际版账户收到账号风险通知,怎么办?