Shell -----grep

grep 是一个强大的文本搜索工具,用于在文件中搜索正则表达式匹配的行。本文介绍了 grep 的基本用法,如多条件匹配、忽略大小写、统计行数、递归查找和与正则表达式结合的使用,还提到了 grep 与其他命令(如 ps、awk 和 wc)的组合使用,以及与正则表达式结合进行IP地址、邮箱和手机号的匹配。
摘要由CSDN通过智能技术生成

简介

  • grep (global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。
  • Unix的grep家族包括grep、egrep和fgrep。egrep和fgrep的命令只跟grep有很小不同。egrep是grep的扩展,支持更多的re元字符, fgrep就是fixed grep或fast grep,它们把所有的字母都看作单词,也就是说,正则表达式中的元字符表示回其自身的字面意义,不再特殊。linux使用GNU版本的grep。它功能更强,可以通过-G、-E、-F命令行选项来使用egrep和fgrep的功能。
  • grep的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到标准输出,不影响原文件内容。grep可用于shell脚本,因为grep通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文件不存在,则返回2。我们利用这些返回值就可进行一些自动化的文本处理工作。

用法:grep [参数] [模式] [文件]
命令格式:grep [option] pattern file;
grep的常用选项:

-V: 打印grep的版本号
 
-E: 解释PATTERN作为扩展正则表达式,也就相当于使用egrep
 
-F :   解释PATTERN作为固定字符串的列表,由换行符分隔,其中任何一个都要匹配。也就相当于使用fgrep。
 
-G:   将范本样式视为普通的表示法来使用。这是默认值。加不加都是使用grep。
 
匹配控制选项:
 
-e :  使用PATTERN作为模式。这可以用于指定多个搜索模式,或保护以连字符( - )开头的图案。指定字符串做为查找文件内容的样式。   
 
-f :  指定规则文件,其内容含有一个或多个规则样式,让grep查找符合规则条件的文件内容,格式为每行一个规则样式。
 
-i :  搜索时候忽略大小写
 
-v:  反转匹配,选择没有被匹配到的内容。
 
-w:匹配整词,精确地单词,单词的两边必须是非字符符号(即不能是字母数字或下划线)
 
-x:仅选择与整行完全匹配的匹配项。精确匹配整行内容(包括行首行尾那些看不到的空格内容都要完全匹配)
 
-y:此参数的效果和指定“-i”参数相同。
 
一般输出控制选项:
 
-c: 抑制正常输出;而是为每个输入文件打印匹配线的计数。
 
--color [= WHEN]:让关键字高亮显示,如--color=auto
 
-L:列出文件内容不符合指定的范本样式的文件名称
 
-l : 列出文件内容符合指定的范本样式的文件名称。
 
-m num:当匹配内容的行数达到num行后,grep停止搜索,并输出停止前搜索到的匹配内容
 
-o: 只输出匹配的具体字符串,匹配行中其他内容不会输出
 
-q:安静模式,不会有任何输出内容,查找到匹配内容会返回0,未查找到匹配内容就返回非0
 
-s:不会输出查找过程中出现的任何错误消息,-q和-s选项因为与其他系统的grep有兼容问题,shell脚本应该避免使用-q和-s,并且应该将标准和错误输出重定向到/dev/null 代替。
 
输出线前缀控制:
 
-b:输出每一个匹配行(或匹配的字符串)时在其前附加上偏移量(从文件第一个字符到该匹配内容之间的字节数)
 
-H:在每一个匹配行之前加上文件名一起输出(针对于查找单个文件),当查找多个文件时默认就会输出文件名
 
-h:禁止输出上的文件名的前缀。无论查找几个文件都不会在匹配内容前输出文件名
 
--label = LABEL:显示实际来自标准输入的输入作为来自文件LABEL的输入。这是特别在实现zgrep等工具时非常有用,例如gzip -cd foo.gz | grep --label = foo -H的东西。看到 也是-H选项。
 
-n:输出匹配内容的同时输出其所在行号。
 
-T:初始标签确保实际行内容的第一个字符位于制表位上,以便对齐标签看起来很正常。在匹配信息和其前的附加信息之间加入tab以使格式整齐。
 
上下文线控制选项:
 
-A num:匹配到搜索到的行以及该行下面的num行
 
-B num:匹配到搜索到的行以及该行上面的num行
 
-C num:匹配到搜索到的行以及上下各num行
 
文件和目录选择选项:
 
-a: 处理二进制文件,就像它是文本;这相当于--binary-files = text选项。不忽略二进制的数据。  
 
 --binary-files = TYPE:如果文件的前几个字节指示文件包含二进制数据,则假定该文件为类型TYPE。默认情况下,TYPE是二进制的,grep通常输出一行消息二进制文件匹配,或者如果没有匹配则没有消息。如果TYPE不匹配,grep假定二进制文件不匹配;这相当于-I选项。如果TYPE是文本,则grep处理a二进制文件,如果它是文本;这相当于-a选项。警告:grep --binary-files = text可能会输出二进制的垃圾,如果输出是一个终端和如果可能有讨厌的副作用终端驱动程序将其中的一些解释为命令。
 
-D:如果输入文件是设备,FIFO或套接字,请使用ACTION处理。默认情况下,读取ACTION,这意味着设备被读取,就像它们是普通文件一样。如果跳过ACTION,设备为 默默地跳过。
 
-d:  如果输入文件是目录,请使用ACTION处理它。默认情况下,ACTION是读的,这意味着目录被读取,就像它们是普通文件一样。
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值