将标题行添加到日志文件的最简单方法

时间:2013-10-22 18:19:50

标签: c# file logging locking

我可以为每个文件添加标题行的最简单方法。我不能把它放在Log()中,因为每次引用test.Log()时都会添加标题行。 我想过引用3个新的int字段,每次我引用一个Log1 / 2/3()它会检查int的值,如果它是1,那么添加标题列,否则不要。我在下面做了一个但是看起来多余了我认为必须有更好的方法。

public class Test
{

   public static string File1 = DateTime.Now.ToString("yyyy-MM-dd") + "test1.csv";
   public static int a = 0;
   public static string File2 = DateTime.Now.ToString("yyyy-MM-dd") + "test2.csv";
   public static string File3 = DateTime.Now.ToString("yyyy-MM-dd") + "test3.csv";     


   private static object _lockObj = new Object();


   public static void Log1(string error, string record)
   { a++;
      if(a==1){
        lock (_lockObj)
        {     
          File.AppendAllText(test.File1, "ERROR" + Environment.NewLine)             
            File.AppendAllText(test.File1, error + "," + record + Environment.NewLine);
        }
      }
     else{
          File.AppendAllText(test.File1, error + "," + record + Environment.NewLine);
       }
    }

    public static void Log2(string message)
    {
        lock (_lockObj)
        {
            File.AppendAllText(test.File2, message + Environment.NewLine);
        }
    }

    public static void Log3(Test c)
    {
        lock (_lockObj)
        {
            File.AppendAllText(test.File3, c + Environment.NewLine);
        }
    }
 }

2 个答案:

答案 0 :(得分:1)

你可以创建一个这样的类: -

public class HeaderOnceAppender : RollingFileAppender 
{
    protected override void WriteHeader()
    {
        if (LockingModel.AcquireLock().Length == 0)
        {
            base.WriteHeader();
        }
    }

答案 1 :(得分:0)

如果您想在创建文件时将标题行放在文件顶部...

if(!System.IO.File.Exists(test.File1)) //if the file doesn't exist
{   //insert your header at the top
    File.AppendAllText(test.File1,"My Header Line")
}

这只会在首次创建文件时附加一次