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

问题描述 投票:12回答:1

我正在使用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

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

format whitespace nlog
1个回答
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是一个布尔值,表示填充结果应修剪为“填充”的最大长度(即我的示例中为5)

© www.soinside.com 2019 - 2024. All rights reserved.