Serilog:打开日志文件

时间:2016-10-11 09:10:29

标签: c# serilog

有没有办法从日志类中获取完整的文件名? 记录器创建一个格式为C:\MyPath\log-20160631.txt

的文件

我无法访问用于记录器初始化的源文件名。

编辑: 这是记录器的初始化:

Log.Logger = new LoggerConfiguration()
            .MinimumLevel.Debug()
            .WriteTo.LiterateConsole()
            .WriteTo.RollingFile(@"C:\MyPath\log.txt")
            .CreateLogger();

在代码中的每个位置,我都可以使用,例如Log.Information()但我如何得到Sink信息?我想获取我传递给滚动文件接收器的文件名。

我目前的解决方法是手动生成真实文件(疯狂丑陋的代码):

public string LogFilename
{
   get
   {
      string path = Path.GetDirectoryName(LogFilenameTemplate);
      string filenameWithoutExtension = Path.GetFileNameWithoutExtension(LogFilenameTemplate);
      string extension = Path.GetExtension(LogFilenameTemplate);
      string date = DateTime.Now.ToString("yyyyMMdd");
      string fullFilename = Path.Combine(path, filenameWithoutExtension + "-" + date + extension);
      return fullFilename;
   }
}

格式来自GitHub Repo

1 个答案:

答案 0 :(得分:2)

不,没有办法从Serilog检索文件名。您最好的选择是使用System.IO类列出目录中的文件,然后打开具有最新修改日期的文件。