如何使用NLog在我当前的目录中创建文本文件?

时间:2013-11-25 16:34:51

标签: c# console nlog

我第一次使用Nlog。我的目标是只写一个文本文件。

在main.c中我有

class Program
{
    private static Logger logger = LogManager.GetCurrentClassLogger();

static void Main(string[] args)
{
        logger.Trace("Sample trace message");
        logger.Debug("Sample debug message");
        logger.Info("Sample informational message");
        logger.Warn("Sample warning message");
        logger.Error("Sample error message");
        logger.Fatal("Sample fatal error message");
    }
}

我的Nlog.config文件如下:

<?xml version="1.0" encoding="utf-8" ?>
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"
      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">

    <targets>
        <target name="logfile" xsi:type="File" fileName="file.txt" />
    </targets>

    <rules>
        <logger name="*" minlevel="Info" writeTo="logfile" />
    </rules>
</nlog>

但我无法在当前目录中创建txt文件。

3 个答案:

答案 0 :(得分:7)

试试这个......

<targets>
    <target name="logfile" xsi:type="File" fileName="${basedir}/file.txt" />
</targets>

请看这里,introduction to NLog

答案 1 :(得分:7)

您是否将NLog.config'副本设置为'始终复制'到输出目录?

如果您按照their tutorial进行操作,则应该可以使用。

答案 2 :(得分:2)

这对我有用${CurrentDir}

例如

<target xsi:type="File" 
    name="ownFile-web" 
    fileName="${CurrentDir}\Logs\nlog-web-${shortdate}.log"
    layout="${longdate}|${event-properties:item=EventId_Id}| [${uppercase:${level}}]${newline}Logger: ${logger}${newline}url: ${aspnet-request-url}${newline}CallSite: ${callsite}${newline}Message: ${message}${onexception:${newline}EXCEPTION:${exception:format=tostring}}${newline}-------${newline}" />

https://github.com/NLog/NLog/wiki/CurrentDir-Layout-Renderer