更改 Eclipse 中 java.util.logging.Logger 输出的颜色和格式
2022-09-03 05:52:25
我正在寻找一种方法来更改Eclipse中java.util.logging.Logger的日志输出的颜色。由于我还没有真正找到解决更改颜色并将其与Logger类相结合的解决方案,因此我想在这里记录我的解决方案。
我正在寻找一种方法来更改Eclipse中java.util.logging.Logger的日志输出的颜色。由于我还没有真正找到解决更改颜色并将其与Logger类相结合的解决方案,因此我想在这里记录我的解决方案。
创建一个继承自格式化程序的新类
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.logging.Formatter;
import java.util.logging.LogRecord;
public class LogFormatter extends Formatter
{
// ANSI escape code
public static final String ANSI_RESET = "\u001B[0m";
public static final String ANSI_BLACK = "\u001B[30m";
public static final String ANSI_RED = "\u001B[31m";
public static final String ANSI_GREEN = "\u001B[32m";
public static final String ANSI_YELLOW = "\u001B[33m";
public static final String ANSI_BLUE = "\u001B[34m";
public static final String ANSI_PURPLE = "\u001B[35m";
public static final String ANSI_CYAN = "\u001B[36m";
public static final String ANSI_WHITE = "\u001B[37m";
// Here you can configure the format of the output and
// its color by using the ANSI escape codes defined above.
// format is called for every console log message
@Override
public String format(LogRecord record)
{
// This example will print date/time, class, and log level in yellow,
// followed by the log message and it's parameters in white .
StringBuilder builder = new StringBuilder();
builder.append(ANSI_YELLOW);
builder.append("[");
builder.append(calcDate(record.getMillis()));
builder.append("]");
builder.append(" [");
builder.append(record.getSourceClassName());
builder.append("]");
builder.append(" [");
builder.append(record.getLevel().getName());
builder.append("]");
builder.append(ANSI_WHITE);
builder.append(" - ");
builder.append(record.getMessage());
Object[] params = record.getParameters();
if (params != null)
{
builder.append("\t");
for (int i = 0; i < params.length; i++)
{
builder.append(params[i]);
if (i < params.length - 1)
builder.append(", ");
}
}
builder.append(ANSI_RESET);
builder.append("\n");
return builder.toString();
}
private String calcDate(long millisecs) {
SimpleDateFormat date_format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Date resultdate = new Date(millisecs);
return date_format.format(resultdate);
}
}
您可以将自定义格式化程序绑定到记录器,如下所示:
Logger logger = Logger.getLogger("logfile.txt");
logger.setUseParentHandlers(false);
ConsoleHandler handler = new ConsoleHandler();
Formatter formatter = new LogFormatter();
handler.setFormatter(formatter);
logger.addHandler(handler);
可以使用此插件为 Eclipse 控制台启用 ANSI 转义码
来源:
一个简单的方法:
log.error("\u001B[31m" + errors.toString() + "\u001B[0m");
log.info("\u001B[32m" + contact.toString() + "\u001B[0m");