我发现grep的——color=always标志非常有用。但是,grep只打印匹配的行(除非您要求上下文行)。假设它打印的每一行都有一个匹配项,那么高亮显示并不能增加尽可能多的功能。
我真的想猫一个文件,并看到整个文件与模式匹配突出显示。
是否有某种方法可以告诉grep打印正在读取的每一行,而不管是否有匹配?我知道我可以编写一个脚本来在文件的每一行上运行grep,但我很好奇标准grep是否可以做到这一点。
我发现grep的——color=always标志非常有用。但是,grep只打印匹配的行(除非您要求上下文行)。假设它打印的每一行都有一个匹配项,那么高亮显示并不能增加尽可能多的功能。
我真的想猫一个文件,并看到整个文件与模式匹配突出显示。
是否有某种方法可以告诉grep打印正在读取的每一行,而不管是否有匹配?我知道我可以编写一个脚本来在文件的每一行上运行grep,但我很好奇标准grep是否可以做到这一点。
当前回答
正如grep -E '|pattern'已经被建议的那样,只是想澄清一下,它也可以突出显示整行。
例如:tail -f somelog | grep——color -E '| \[2\]。*'(特别是-E '|部分):
其他回答
我使用以下命令来达到类似的目的:
grep -C 100 searchtext文件
这将说grep打印100 * 2行上下文,在高亮显示的搜索文本之前和之后。
这里有一些类似的东西。很有可能,无论如何你都会用得更少,所以试试这个:
less -p pattern file
它将突出显示该模式,并跳转到该模式在文件中第一次出现的位置。
你可以用n跳到下一个出现点,用p跳到前一个出现点,用q退出。
要在查看整个文件时突出显示模式,h可以这样做。
另外,它使用不同的颜色来代表不同的图案。
cat FILE | h 'PAT1' 'PAT2' ...
您还可以将h的输出输出到less -R,以便更好地读取。
如果要grep并为每个图案使用一种颜色,cxpgrep可能很适合。
下面是一个shell脚本,它使用Awk的gsub函数来替换你正在搜索的文本,使用正确的转义序列以亮红色显示:
#! /bin/bash
awk -vstr=$1 'BEGIN{repltext=sprintf("%c[1;31;40m&%c[0m", 0x1B,0x1B);}{gsub(str,repltext); print}' $2
像这样使用它:
$ ./cgrep pattern [file]
不幸的是,它不具备grep的所有功能。
要了解更多信息,您可以参考Linux Journal上的文章“所以您喜欢颜色”
我把这个添加到我的.bash_aliases中:
highlight() {
grep --color -E "$1|\$"
}