正则表达式和文本搜索工具grep

前端之家收集整理的这篇文章主要介绍了正则表达式和文本搜索工具grep前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

正则表达式是由字面文本和具有特殊意义的符号组成的。我们可以根据具体需求,使用它们构造出合适的正则表达式来匹配文本。它是一种匹配文本的通用语言。正则表达式是模式匹配技术的核心,借助合适的正则表达式,可以生成我们所需的各类输出结果,例如过滤、剥离、替换、搜索等。



正则表达式的基本组成部分

^ #行起始标记(使用cat -a显示空格,行首,行尾等标记。)
  #示例 ^It 匹配以It起始的行
$ #行尾标记                                         
  #示例 It$ 匹配以It结尾的行
. #匹配任意一个字符
   #示例:Hack.匹配Hackl和Hacki,但是不能匹配Hackl2和Hackil,它只能匹配单个字符
[] #匹配包含在[字符]之中的任意一个字符
   #示例:coo[kl] 匹配cook 或 cool
[^] #匹配除[^字符]之外的任意一个字符
   #示例:9[^01] 匹配92 、93,但不匹配91或90
[-] #匹配[]中指定范围内的任意一个字符
   #示例 [1-5]匹配1至5的任意一个数字,[a-z]匹配a到z之间的任意一个字母
?  #匹配之前的项一次或零次
   #示例:colou?r匹配color或colour 但不能匹配colouur
+  #匹配之前项一次或多次
   #Rollo-9+匹配Rollo-99、Rollo-9但不匹配Rollo-
*  #匹配之前项0次或多次
   #示例:co*l 匹配cl、col、cool等
() #创建一个用于匹配的子串
   #示例:ma\(tar\)?x匹配max或matarx
{n} #匹配之前的项n次
    #[0-9]\{3\}匹配任意一个三位数,可扩展为[0-9][0-9][0-9]
{n,} #匹配之前项至少n次
     #示例:[0-9]\{2,\}匹配任意一个两位或更多数字
{n,m} #之前的项匹配至少n次,最多匹配m次
|     #匹配左边项或右边项
      #示例:Oct\(1st|2nd\)匹配Oct 1st或Oct 2nd
\    #转义符



grep是使用正则表达式来进行文本模式匹配的文本搜索工具。

(1)搜索包含特定模式的文本行

grep pattern filename filename #可同时搜索多个文件
echo "this a word"|grep word #或从stdin中读取


(2)用--color选项在输出行中着重标记匹配到的单词

grep word filename --color=auto


(3)grep只解释模式中的某些特殊字符。如果要使用完整的正则表达式,需要使用egrep或加-E选项使用扩展正则表达式。

grep "[a-z]+" filename


(4)-o 只输出匹配到的文本部分

(5)-v打印匹配到的行之外的文本

(6)-c打印匹配到的行,非匹配次数

(7)-n打印包含匹配字串的行号

(8)-e匹配多个模式

猜你在找的正则表达式相关文章