NLog:使用空格格式化日志级别

时间:2013-12-18 10:34:51

标签: format whitespace nlog

我正在使用NLog进行日志记录。 目前我的Layout-String是:

"${date:format=dd.MM.yyyy HH\\:mm\\:ss,fff} | ${level:uppercase=true} | ${message}"

这会产生以下日志:

18.12.2013 11:23:14,834 | INFO | this is an info
18.12.2013 11:23:14,835 | TRACE | this is a trace

我现在想要的是格式化" $ level"填充Whitespaces,使其看起来像一个包含5个字符的表。

我想:

18.12.2013 11:23:14,834 | INFO  | this is an info
18.12.2013 11:23:14,835 | TRACE | this is a trace

我没有发现任何遗憾......有人可以帮忙吗?

1 个答案:

答案 0 :(得分:17)

尝试使用PaddingLayoutRendererWrapper。我不确定一个好的配置示例在哪里,但是NLog源代码库中的源代码位于此处,所以也许您可以对正确的配置进行反向工程:

https://github.com/NLog/NLog/blob/master/src/NLog/LayoutRenderers/Wrappers/PaddingLayoutRendererWrapper.cs

我想你会做这样的事情:

"${date:format=dd.MM.yyyy HH\\:mm\\:ss,fff} | ${padding:padding=5,fixedlength=true:${level:uppercase=true}} | ${message}"

希望该示例将填充左侧5个空格的所有日志级别值,然后修剪为绝对长度5。

padding=5表示向左添加5个填充字符(默认为' ')(负表示右侧填充)

fixedlength=true是一个布尔值,表示填充结果应修剪为“padding”的最大长度(即我的例子中为5)