我有一个使用文件追加器和控制台追加器的记录器。我的代码中有一行我只想去控制台上传。有没有办法在不制作新记录器的情况下做到这一点?
或者,我可以制作另一个仅使用控制台的记录器,但我似乎无法完成。我可以找到的所有示例都使用类或方法名称。我正在尝试使用我在app.config中提供的名称。
这是我的appconfig:
<log4net>
<appender name="Console" type="log4net.Appender.ConsoleAppender">
<layout type="log4net.Layout.PatternLayout">
<!-- Pattern to output the caller's file name and line number -->
<conversionPattern value="%level [%thread] %date - %message%newline" />
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="All" />
</filter>
</appender>
<appender name="RollingFile" type="log4net.Appender.RollingFileAppender">
<file value="D:\Something\Log\IntegrationTests\IntegrationTests.log" />
<appendToFile value="false" />
<rollingStyle value="Size" />
<maximumFileSize value="250MB" />
<maxSizeRollBackups value="20" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%level [%thread] %date - %message%newline" />
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="All" />
</filter>
</appender>
<root>
<level value="ALL" />
<appender-ref ref="Console" />
<appender-ref ref="RollingFile" />
</root>
<logger name="consoleOnly">
<level value="ALL" />
<appender-ref ref="Console" />
</logger>
</log4net>
这是我试图获得“consoleOnly”Logger的一行。
ILog log = LogManager.GetLogger("consoleOnly");
log.Debug("Poop");
我是怎么做到的?
答案 0 :(得分:0)
ILog log = LogManager.GetLogger(&#34; consoleOnly&#34;);
log.Debug(&#34;船尾&#34);
这应该可以正常工作。但我认为您需要将可加性设置为false,否则它也会使用根记录器进行记录。
例如
def minremo(lst):
lst.sort()
lst.reverse()
lst.pop()
return lst