关于在grep命令中使用{}的有趣现象

在使用grep命令时我们可能使用{}的正则表达式来搜索中括号前的关键字在文本中显示次数,
常见的有:
\{n\}匹配前面字符出现n次
\{n,\}匹配前面字符至少出现n次
\{n,m\}匹配前面字符出现n~m次

通过以上三个表达式我们可以理解为,用{}是为了将前面的字符出现n次、n次以上、n-m次,如果我们需要匹配前面的字符有两个其中一个是固定字符则会输出以下:
[root@hpf-linux222]#aliasegrep='egrep--color'

wKiom1UrGpigQIRjAADLA1GdYxU217.jpg

通过颜色显然输出的与我们要求的一样,但是我们需要匹配前面的字符有两个,其中这两个字符都是需要多次匹配的,那我们需要用()将哪两个字符括起来,若我们只是加了()的字符而没有添加固定的字符则会出现以下现象:

wKiom1UrGeLgPd_FAAJEXmVYDus756.jpg

显然若没有固定的字符则会将匹配字符匹配为中括号数字的倍数个,若要添加固定的字符则不会出现上述现象了详见以下:

wKioL1UrHSqyqjhmAALSZAc-sRo350.jpg

以上如果列举还有很多,我这就不一一列举了有兴趣的童鞋可以尝试下,关于以上问题我也不是很清楚若有知道的童鞋请指导指导我,非常感谢!

故今后我们在匹配搜索多次时不加入固定的字符,则会出现与我们想要的输出有一定的偏差,希望在以后的工作中在匹配多次是最好带上固定字符,避免出现不必要的麻烦!

相关文章

正则替换html代码中img标签的src值在开发富文本信息在移动端...
正则表达式
AWK是一种处理文本文件的语言,是一个强大的文件分析工具。它...
正则表达式是特殊的字符序列,利用事先定义好的特定字符以及...
Python界一名小学生,热心分享编程学习。
收集整理每周优质开发者内容,包括、、等方面。每周五定期发...