我正在使用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
我没有发现任何遗憾......有人可以帮忙吗?
答案 0 :(得分:17)
尝试使用PaddingLayoutRendererWrapper。我不确定一个好的配置示例在哪里,但是NLog源代码库中的源代码位于此处,所以也许您可以对正确的配置进行反向工程:
我想你会做这样的事情:
"${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)