我对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”的零次或多次重复没有给出任何输出?
我在这里缺少什么。谢谢你的帮助!
答案 0 :(得分:8)
因为您的输入中没有任何内容与i
匹配,而是重复s
次0次或更多次g
。 "文章很好"无法匹配,因为它在s
之后有一个空格,而不是g
。模式is\s*g
匹配,因为\s
是一种匹配任何类型空格的特殊模式 - 因此整体模式为is
,然后是任意数量的空间,然后g
,自然匹配"是g"。
答案 1 :(得分:3)
我在您的输入中看不到ig
,isg
,issg
,issssg
...
由于我不知道你想要匹配什么,这是我最好的猜测:
grep -P "is.*g" test.txt
答案 2 :(得分:1)
在使用grep之前,您应首先看到正则表达式,您也会发现它对其他命令有用... http://www.regular-expressions.info/
答案 3 :(得分:0)
前一个正则表达式原子重复0次或更多,该原子为\s
。因此\s*
可以匹配tab-space-tab-space-space。