0

我的问题与此类似:语法高亮/着色 cat。但不完全一样。

一个工具,这样做会很棒:

  • cat一份文件
  • x用颜色突出显示单词cx
  • y用颜色突出显示单词cy

等有没有人知道这样的事情?


这样做的“现实动机”是:我有一个日志(log4cxx例如由生成),我想DEBUG用一种颜色突出显示;ERROR在另一个; WARN在第三等等。

基本上,我想要实现的是:如何设置 log4cxx 控制台输出的颜色?

cat我考虑了和grep(使用自定义颜色)之间的某种组合。但是外部工具也可以完成这项工作(如果存在)。

想法?


编辑: 谢谢,@sjngm!很好的建议。我对其进行了一些修改(现在可以用作alias并且整行都被突出显示)。我决定发布我的修改,因为这可能对某人有用:

 # escaped ' ------------v;         light red ------vvvv;  red ------------vvvv;  yellow -------vvvvv;  green ---------vvvv;  brown ----------vvvv;  dark gray ------vvvv
 alias log_color='nawk '"'"'BEGIN { arr["FATAL"] = "1;31"; arr["ERROR"] = "0;31"; arr["WARN"] = "1;33"; arr["INFO"] = "0;32"; arr["DEBUG"] = "0;33"; arr["TRACE"] = "1;30"  } { l = $0; for (pattern in arr)     { gsub(".*" pattern ".*", "\033[" arr[pattern] "m&\033[0m", l); } print l; }'"'"
 alias log_error='grep "FATAL\|ERROR\|WARN"'

示例用法:

$ cat log_file | log_color
$ cat log_file | log_error | log_color
4

2 回答 2

1

不久前,我也为日志文件做了类似的事情,其中nawk​​:

cat yourfile | nawk '
BEGIN {
    arr["EXCEPTION"] = "0;31";
    arr["\\[ERROR\\]"] = "1;31";
    arr["\\[WARN\\]"] = "0;31";
    arr["\\[INFO\\]"] = "1;34";
}
{
    l = $0;
    for (pattern in arr) {
        gsub(pattern, "\033[" arr[pattern] "m&\033[0m", l);
    }
    print l;
}'

配置部分应该符合你的x => cx风格,你也可以使用tail -f代替cat.

老实说,我认为没有工具可以解决它,因为它并不复杂。

于 2013-06-20T12:18:26.893 回答
0

在这里,您将找到一个 sed-wrapper,它只接受颜色和图案作为命令行参数:

https://stackoverflow.com/a/13593327/1033410

(用法:cat yourfile | colorize.sh red ERROR yellow WARN blue 'user .* logged in')

于 2013-10-16T06:57:26.490 回答