grep命令主要是做什么的呢 ?下面我们就来研究下。

grep命令简单来说就是“过滤”。就是把想看的数据通过grep过滤出来,把不想看的通过grep过滤掉。

它是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来,Unix的grep家族包括(egrep,fgrep,grep)。egrep和fgrep的命令跟grep有所不同,egrep是grep的扩展,支持更多的re元字符,fgrep表示就是fixed grep或fast grep,它们把所有的字母都看作单词,也就是说正则表达式中的元字符表示自身的意思,不再特殊,linux使用的GNU版本的grep本身就强大,可以通过-G,-E,-F 命令行来选项egrep和fgrep的功能。

选项:

-A   #       --after                         表示后#行 

-B   #     --before                      表示前#行

  -C  #   --context                     表示“前后”各#行      

-D          --devices                       设置对设备,FIFO,管道的操作,读取,跳过

-E          --extended-regexp       扩展正则表达式egrep

-F         --fixed-strings               一个换行符分隔的字符串的集合fgrep

   -G         --basic-regexp              基本正则

-H         --with-filename            当搜索多个文件,显示匹配的文件名前缀

-I                                              不匹配二进制的东西 

-L        --files-without--math     匹配多个文件时,显示不匹配的文件名

   -P         -----perl-regexp            调用的perl正则

     -R/-r    --recursive                    递归调用

-V        --version                      显示版本信息

-U        --binary                       使用标志高亮匹配字符串

小写选项:

-a         --text                           不要忽略二进制数据

    -b       --byte-offset                  打印匹配行前面答应该行所在的块行码

    -c        --count                         显示匹配的行数

   -d          --directories               目录操作,读取,递归跳过

-e         --regexp                      指定字符串作为查找文件内容范本样式

-f           ---file                           从文件中获得匹配模式

-h          --no--filename            当搜索多个文件,不显示文件名的前缀

-i            --ignore-case             不区分大小写

-l            --files-with-matches   匹配多个文件时,显示匹配的文件名

   -n           --line-number             显示的内容加上行号

-q          --quiet,--silent          不显示任何东西

   -s         --no-messages           不显示错误信息

   -v          --invert-match            显示不匹配的行

-w         --word-regexp            匹配整个单词

-x          --line-regexp              匹配整行

-y                                            此选项跟-i选项相同

-o         --only-matching          只显示一行中匹配PATTERN的数据

  -m         --max-count                匹配的最大数

*注:单词由字母,数字,下划线组成

正则表达式:^   表示以^grep开头的行

           $     表示行尾锚定,用于模式的最右侧  

            .      表示任意单个字符  

       *       匹配前面的字符任意次

      .*    任意长度字符

        []     匹配指定的范围内的内容

             [^]       匹配不在范围的内容

        \(..\)      标记匹配字符,如\(love\) ,love被标记为1

       \<        锚定单词的开始,即词首锚定,用于单词模式的开始

        \>         锚定单词的词尾,即词尾锚定,用于单词模式的结束,锁定单词的结束

       \{n\}  匹配前面的字符n次

    \{,n\}  匹配前面的字符至多n次, <=n

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

    \{n,\}  匹配前面的字符至少n次, 最多无限次

    \+            匹配前面的字符出现最少1次, 即:肯定有且>=1次

    \?    匹配前面的字符出现0次或1次,即:可有可无

    ^$         空行

    ^[[:space:]]*$         空白行

    ^PATTERN$         用于模式匹配整行

    \<PATTERN\>      匹配整个单词

    \|                           或者

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

   后向引用:\(string\string2\)\)

          1\:string\(string2\)

          2\:string2

    

最新文章

  1. 20160929001 Guid生成
  2. Azure ARM (10) ARM模式下的虚拟机和Classic Model虚拟机的区别
  3. Unity操作
  4. wiegand/韦根
  5. Java-SSI框架学习
  6. POJ3267 The Cow Lexicon(dp)
  7. Hadoop SecondaryNameNode
  8. 网络获取数据的Xml的Pull解析
  9. Java对象流的使用
  10. 不学无术的下场——OO第一单元总结
  11. http: server gave HTTP response to HTTPS client &amp; Get https://192.168.2.119/v2/: dial tcp 192.168.2.119:443: getsockopt: connection refused
  12. 力扣(LeetCode) 849. 到最近的人的最大距离
  13. [转]ConcurrentHashMap原理分析
  14. Quartz定时任务详解一
  15. es-07-head插件-ik分词器插件
  16. VLAN,GRE,VXLAN
  17. Android开发日记(一)
  18. PID控制算法的C语言实现六&#160;抗积分饱和的PID控制算法C语言实现
  19. 编程之美 set 4 找到符合条件的数
  20. 启动memcache 服务器端

热门文章

  1. UOJ#454-[UER #8]打雪仗【通信题】
  2. 如何借助 JuiceFS 为 AI 模型训练提速 7 倍
  3. Go语言之结构体与方法
  4. php链接mysql,php链接mysql的常用方法
  5. C语言实现简易计算器(可作加减乘除)
  6. 那些我用Windows时必备的软件
  7. 2021.5.22 vj补题
  8. Shell 编程 基础用法
  9. 【数据结构与算法Python版学习笔记】图——强连通分支
  10. LCP 07.传递消息