Linux grep命令中的混乱

时间:2012-01-07 00:37:02

标签: grep

我对grep有一个非常基本的困惑。假设我有一个以下文件来grep:

test.txt:
This is an article 
from some newspaper
Article is good 
newspaper is not.

现在,如果我使用以下表达式

grep -P "is\s*g" test.txt

我得到了这句话:

Article is good

但是,如果我这样做:

grep -P "is*g" test.txt

我什么都没得到。我的问题是因为asterix(*)是一个表示前一个字符重复0次或更多的通配符,所以grep的输出不应该相同。为什么“s”的零次或多次重复没有给出任何输出?

我在这里缺少什么。谢谢你的帮助!

4 个答案:

答案 0 :(得分:8)

因为您的输入中没有任何内容与i匹配,而是重复s次0次或更多次g。 "文章很好"无法匹配,因为它在s之后有一个空格,而不是g。模式is\s*g匹配,因为\s是一种匹配任何类型空格的特殊模式 - 因此整体模式为is,然后是任意数量的空间,然后g,自然匹配"是g"。

答案 1 :(得分:3)

我在您的输入中看不到igisgissgissssg ...

由于我不知道你想要匹配什么,这是我最好的猜测:

grep -P "is.*g" test.txt

答案 2 :(得分:1)

在使用grep之前,您应首先看到正则表达式,您也会发现它对其他命令有用... http://www.regular-expressions.info/

答案 3 :(得分:0)

前一个正则表达式原子重复0次或更多,该原子为\s。因此\s*可以匹配tab-space-tab-space-space。