11

App.configは次のようになります。

<appender name="MemoryAppender" type="log4net.Appender.MemoryAppender">
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%date [%thread] %-5level - %message" />
  </layout>
</appender>

コードは次のようになります。

foreach (var ev in events)
{
   string msg = ev.RenderedMessage;
}

から返される文字列ev.RenderedMessage単なるメッセージであり、パターン全体ではありません。私もWriteRenderedMessageaで使ってみましたStringWriterが、結果は同じでした。パターンを適用したメッセージを取得する方法はありますか?

4

1 に答える 1

18

見つけた :)

var events = _ma.GetEvents();
string result = "";
using (StringWriter writer = new StringWriter())
{
    foreach (var ev in events)
    {
        _ma.Layout.Format(writer, ev);
        writer.Write(Environment.NewLine);
    }
    result = writer.ToString();
}
于 2013-01-21T12:09:06.950 に答える