是否有一种方法使grep从匹配搜索表达式的文件中输出“单词”?

如果我想在一些文件中找到“th”的所有实例,我可以这样做:

grep "th" *

但是输出会是这样的(粗体是我的);

some-text-file : the cat sat on the mat  
some-other-text-file : the quick brown fox  
yet-another-text-file : i hope this explains it thoroughly 

我想让它输出什么,使用相同的搜索,是:

the
the
the
this
thoroughly

这可能使用grep吗?或者使用另一种工具组合?


当前回答

你也可以试试pcregrep。在grep中也有一个-w选项,但在某些情况下,它不能像预期的那样工作。

从维基百科:

cat fruitlist.txt
apple
apples
pineapple
apple-
apple-fruit
fruit-apple

grep -w apple fruitlist.txt
apple
apple-
apple-fruit
fruit-apple

其他回答

交叉分发安全答案(含windows minGW?)

grep -h "[[:alpha:]]*th[[:alpha:]]*" 'filename' | tr ' ' '\n' | grep -h "[[:alpha:]]*th[[:alpha:]]*"

如果你使用的是不包含-o选项的旧版本的grep(如2.4.2),那么使用上面的方法。否则使用下面的简单版本来维护。

Linux交叉分发安全答案

grep -oh "[[:alpha:]]*th[[:alpha:]]*" 'filename'

总结一下:-oh输出正则表达式匹配到文件内容(而不是文件名),就像你期望正则表达式在vim/etc中工作一样…然后,您将搜索什么单词或正则表达式,这取决于您!只要你继续使用POSIX而不是perl语法(请参阅下文)

更多内容来自grep手册

-o      Print each match, but only the match, not the entire line.
-h      Never print filename headers (i.e. filenames) with output lines.
-w      The expression is searched for as a word (as if surrounded by
         `[[:<:]]' and `[[:>:]]';

为什么最初的答案并不适用于所有人

\w的用法因平台而异,因为它是一种扩展的“perl”语法。因此,那些局限于POSIX字符类的grep安装使用[[:alpha:]],而不是perl中的\w。有关正则表达式的更多信息,请参见维基百科页面

最终,上面的POSIX答案将更加可靠,不管grep使用的是什么平台(是原始平台)

对于不带-o选项的grep的支持,第一个grep输出相关的行,tr将空格分割为新行,最后一个grep只过滤相应的行。

(PS:我知道现在大多数平台都已经为\w....打了补丁但总有落后的)

感谢@AdamRosenfield回答中的“-o”

我有一个类似的问题,寻找grep/pattern regex和“匹配的模式找到”作为输出。

最后,我使用了选项-o的egrep(相同的正则表达式在grep -e或-G上没有给我相同的egrep结果)

所以,我认为这可能是类似于(我不是一个正则表达式大师):

egrep -o "the*|this{1}|thoroughly{1}" filename

试试grep -o:

grep -oh "\w*th\w*" *

编辑:匹配菲尔的评论。

从文档中可以看出:

-h, --no-filename
    Suppress the prefixing of file names on output. This is the default
    when there is only  one  file  (or only standard input) to search.
-o, --only-matching
    Print  only  the matched (non-empty) parts of a matching line,
    with each such part on a separate output line.

ripgrep

下面是使用ripgrep的示例:

rg -o "(\w+)?th(\w+)?"

它会匹配所有与th匹配的单词。

grep --color -o -E "Begin.{0,}?End" file.txt

? -尽可能少的匹配直到结束

在macos终端上测试